/* * 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.Test; /** * * @author Joerg Rathlev */ public class LinearAxisTest { @Test public void testSimpleMapping() { IAxis axis = new LinearAxis(0.0, 9.0, 10); assertEquals(0, axis.valueToCoordinate(0.0)); assertEquals(1, axis.valueToCoordinate(1.0)); assertEquals(9, axis.valueToCoordinate(9.0)); } @Test public void valuesOutsideDataRange() throws Exception { IAxis axis = new LinearAxis(0.0, 9.0, 10); assertEquals(20, axis.valueToCoordinate(20.0)); assertEquals(-10, axis.valueToCoordinate(-10.0)); } @Test public void testRounding() throws Exception { LinearAxis axis = new LinearAxis(0.0, 9.0, 10); assertEquals(0, axis.valueToCoordinate(0.1)); assertEquals(0, axis.valueToCoordinate(0.49)); assertEquals(1, axis.valueToCoordinate(0.5)); assertEquals(1, axis.valueToCoordinate(0.9)); assertEquals(1, axis.valueToCoordinate(1.49)); assertEquals(2, axis.valueToCoordinate(1.5)); // negative values assertEquals(0, axis.valueToCoordinate(-0.1)); assertEquals(0, axis.valueToCoordinate(-0.5)); assertEquals(-1, axis.valueToCoordinate(-0.51)); } @Test public void testScaling() throws Exception { IAxis axis = new LinearAxis(0.0, 1.0, 101); assertEquals(0, axis.valueToCoordinate(0.0)); assertEquals(100, axis.valueToCoordinate(1.0)); assertEquals(50, axis.valueToCoordinate(0.5)); assertEquals(1, axis.valueToCoordinate(0.01)); } @Test public void testSetDataRange() throws Exception { IAxis axis = new LinearAxis(0.0, 9.0, 10); assertEquals(0, axis.valueToCoordinate(0.0)); axis.setDataRange(-9.0, 9.0); assertEquals(5, axis.valueToCoordinate(0.0)); } @Test public void testSetDisplaySize() throws Exception { IAxis axis = new LinearAxis(0.0, 10.0, 10); assertEquals(5, axis.valueToCoordinate(5.0)); axis.setDisplaySize(20); assertEquals(10, axis.valueToCoordinate(5.0)); } @Test public void testInvalidDataRange() throws Exception { // This test simply checks that an axis can be created with an invalid // data range. IAxis axis = new LinearAxis(0.0, -10.0, 10); axis.setDataRange(10.0, 0.0); } @Test public void testExtrema() throws Exception { IAxis axis = new LinearAxis(0.0, 9.0, 10); assertEquals(Integer.MAX_VALUE, axis.valueToCoordinate(Double.MAX_VALUE)); assertEquals(Integer.MIN_VALUE, axis.valueToCoordinate(-Double.MAX_VALUE)); assertEquals(Integer.MAX_VALUE, axis.valueToCoordinate(Double.POSITIVE_INFINITY)); assertEquals(Integer.MIN_VALUE, axis.valueToCoordinate(Double.NEGATIVE_INFINITY)); // note: Double.MIN_VALUE is smallest *positive* nonzero value! assertEquals(0, axis.valueToCoordinate(Double.MIN_VALUE)); } @Test public void testLegalValues() throws Exception { IAxis axis = new LinearAxis(0.0, 9.0, 10); // All values except NaN should be legal. assertTrue(axis.isLegalValue(Double.NEGATIVE_INFINITY)); assertTrue(axis.isLegalValue(Double.POSITIVE_INFINITY)); assertTrue(axis.isLegalValue(Double.MAX_VALUE)); assertTrue(axis.isLegalValue(-Double.MAX_VALUE)); assertFalse(axis.isLegalValue(Double.NaN)); } @Test public void testCalculateTicks() throws Exception { IAxis axis = new LinearAxis(0.0, 9.0, 1000); // major ticks only List<Tick> ticks = axis.calculateTicks(100, -1); // expected: 10 ticks at 0.0, 1.0, ..., 9.0 assertEquals(10, ticks.size()); for (int i = 0; i < 10; i++) { assertEquals(i, ticks.get(i).value(), 0.001); } } @Test public void testCalculateIntegerTicks() throws Exception { IAxis axis = new LinearAxis(0.0, 2.0, 1000); // major ticks only List<Tick> ticks = axis.calculateIntegerTicks(100, -1); // Because we want ticks only at integral numbers, we expect 3 ticks // at 0.0, 1.0, 2.0 assertEquals(3, ticks.size()); for (int i = 0; i < 3; i++) { assertEquals(i, ticks.get(i).value(), 0.001); } } }