/*
* Copyright (c) 2008 Stiftung Deutsches Elektronen-Synchrotron,
* Member of the Helmholtz Association, (DESY), HAMBURG, GERMANY.
*
* THIS SOFTWARE IS PROVIDED UNDER THIS LICENSE ON AN "../AS IS" BASIS.
* WITHOUT WARRANTY OF ANY KIND, EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED
* TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR PARTICULAR PURPOSE AND
* NON-INFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE
* FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR
* THE USE OR OTHER DEALINGS IN THE SOFTWARE. SHOULD THE SOFTWARE PROVE DEFECTIVE
* IN ANY RESPECT, THE USER ASSUMES THE COST OF ANY NECESSARY SERVICING, REPAIR OR
* CORRECTION. THIS DISCLAIMER OF WARRANTY CONSTITUTES AN ESSENTIAL PART OF THIS LICENSE.
* NO USE OF ANY SOFTWARE IS AUTHORIZED HEREUNDER EXCEPT UNDER THIS DISCLAIMER.
* DESY HAS NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS,
* OR MODIFICATIONS.
* THE FULL LICENSE SPECIFYING FOR THE SOFTWARE THE REDISTRIBUTION, MODIFICATION,
* USAGE AND OTHER RIGHTS AND OBLIGATIONS IS INCLUDED WITH THE DISTRIBUTION OF THIS
* PROJECT IN THE FILE LICENSE.HTML. IF THE LICENSE IS NOT INCLUDED YOU MAY FIND A COPY
* AT HTTP://WWW.DESY.DE/LEGAL/LICENSE.HTM
*/
package org.csstudio.sds.components.ui.internal.figures;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertTrue;
import java.util.List;
import org.junit.Before;
import org.junit.Test;
/**
* @author Joerg Rathlev
*
*/
public class LogarithmicAxisTest {
private IAxis _axis;
@Before
public void setUp() {
// axis:
// 4.9E-324 = Double.MIN_VALUE
// 1e-323 --> y = -966
// ... ...
// 1e-1 --> y = 0
// 1e0 --> y = 3
// 1e1 --> y = 6
// 1e2 --> y = 9
// ... ...
// 1e308 --> y = 927
// 1.79..E308 = Double.MAX_VALUE
_axis = new LogarithmicAxis(0.1, 100.0, 10);
}
@Test
public void testValueToCoordinate() throws Exception {
assertEquals(0, _axis.valueToCoordinate(0.1));
assertEquals(3, _axis.valueToCoordinate(1.0));
assertEquals(6, _axis.valueToCoordinate(10.0));
assertEquals(9, _axis.valueToCoordinate(100.0));
}
@Test
public void invalidDataRange() throws Exception {
// Make sure that the axis can be created with or set to an invalid
// data range.
final IAxis axis = new LogarithmicAxis(10.0, 1.0, 10);
axis.setDataRange(20.0, 5.0);
// For logarithmic axis, any range that includes zero is invalid, too!
axis.setDataRange(0.0, 10.0);
axis.setDataRange(-10.0, 10.0);
}
@Test
public void testSetDataRange() throws Exception {
assertEquals(9, _axis.valueToCoordinate(100.0));
_axis.setDataRange(1.0, 1e9);
assertEquals(2, _axis.valueToCoordinate(100.0));
}
@Test
public void testSetDisplaySize() throws Exception {
assertEquals(3, _axis.valueToCoordinate(1.0));
_axis.setDisplaySize(100);
assertEquals(33, _axis.valueToCoordinate(1.0));
}
@Test
public void valuesOutsideRange() throws Exception {
assertEquals(12, _axis.valueToCoordinate(1000.0));
assertEquals(-3, _axis.valueToCoordinate(0.01));
}
@Test
public void testExtrema() throws Exception {
assertEquals(-966, _axis.valueToCoordinate(1e-323));
assertEquals(927, _axis.valueToCoordinate(1e308));
assertEquals(Integer.MAX_VALUE, _axis.valueToCoordinate(Double.POSITIVE_INFINITY));
}
@Test
public void testLegalValues() throws Exception {
// All values > 0 should be legal
assertTrue(_axis.isLegalValue(Double.POSITIVE_INFINITY));
assertTrue(_axis.isLegalValue(Double.MAX_VALUE));
assertTrue(_axis.isLegalValue(Double.MIN_VALUE));
assertFalse(_axis.isLegalValue(Double.NaN));
assertFalse(_axis.isLegalValue(0.0));
assertFalse(_axis.isLegalValue(-Double.MIN_VALUE));
assertFalse(_axis.isLegalValue(-1.0));
assertFalse(_axis.isLegalValue(-Double.MAX_VALUE));
assertFalse(_axis.isLegalValue(Double.NEGATIVE_INFINITY));
}
@Test
public void testCalculateTicks() throws Exception {
final IAxis axis = new LogarithmicAxis(1e0, 1e9, 1000);
// major ticks only
final List<Tick> ticks = axis.calculateTicks(100, -1);
// expected: 10 ticks at 1e0, 1e1, ..., 1e9
//System.out.println(ticks);
assertEquals(10, ticks.size());
for (int i = 0; i < 10; i++) {
assertEquals(Math.pow(10, i), ticks.get(i).value(), 0.001);
}
}
}