RangeTest.java 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357
  1. /* ===========================================================
  2. * JFreeChart : a free chart library for the Java(tm) platform
  3. * ===========================================================
  4. *
  5. * (C) Copyright 2000-2014, by Object Refinery Limited and Contributors.
  6. *
  7. * Project Info: http://www.jfree.org/jfreechart/index.html
  8. *
  9. * This library is free software; you can redistribute it and/or modify it
  10. * under the terms of the GNU Lesser General Public License as published by
  11. * the Free Software Foundation; either version 2.1 of the License, or
  12. * (at your option) any later version.
  13. *
  14. * This library is distributed in the hope that it will be useful, but
  15. * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
  16. * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
  17. * License for more details.
  18. *
  19. * You should have received a copy of the GNU Lesser General Public
  20. * License along with this library; if not, write to the Free Software
  21. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
  22. * USA.
  23. *
  24. * [Oracle and Java are registered trademarks of Oracle and/or its affiliates.
  25. * Other names may be trademarks of their respective owners.]
  26. *
  27. * --------------
  28. * RangeTest.java
  29. * --------------
  30. * (C) Copyright 2003-2014, by Object Refinery Limited and Contributors.
  31. *
  32. * Original Author: David Gilbert (for Object Refinery Limited);
  33. * Contributor(s): Sergei Ivanov;
  34. *
  35. * Changes
  36. * -------
  37. * 14-Aug-2003 : Version 1 (DG);
  38. * 18-Dec-2007 : Additional tests from Sergei Ivanov (DG);
  39. * 08-Jan-2012 : Added test for combine() method (DG);
  40. * 23-Feb-2014 : Added isNaNRange() test (DG);
  41. *
  42. */
  43. package org.jfree.data;
  44. import static org.junit.Assert.assertEquals;
  45. import static org.junit.Assert.assertFalse;
  46. import static org.junit.Assert.assertTrue;
  47. import static org.junit.Assert.assertNull;
  48. import static org.junit.Assert.fail;
  49. import org.jfree.chart.TestUtilities;
  50. import org.junit.Test;
  51. /**
  52. * Tests for the {@link Range} class.
  53. */
  54. public class RangeTest {
  55. /**
  56. * Confirm that the constructor initializes all the required fields.
  57. */
  58. @Test
  59. public void testConstructor() {
  60. Range r1 = new Range(0.1, 1000.0);
  61. assertEquals(r1.getLowerBound(), 0.1, 0.0d);
  62. assertEquals(r1.getUpperBound(), 1000.0, 0.0d);
  63. try {
  64. /*Range r2 =*/ new Range(10.0, 0.0);
  65. fail("Lower bound cannot be greater than the upper");
  66. }
  67. catch (Exception e) {
  68. // expected
  69. }
  70. }
  71. /**
  72. * Confirm that the equals method can distinguish all the required fields.
  73. */
  74. @Test
  75. public void testEquals() {
  76. Range r1 = new Range(0.0, 1.0);
  77. Range r2 = new Range(0.0, 1.0);
  78. assertEquals(r1, r2);
  79. assertEquals(r2, r1);
  80. r1 = new Range(0.0, 1.0);
  81. r2 = new Range(0.5, 1.0);
  82. assertFalse(r1.equals(r2));
  83. r1 = new Range(0.0, 1.0);
  84. r2 = new Range(0.0, 2.0);
  85. assertFalse(r1.equals(r2));
  86. // a Range object cannot be equal to a different object type
  87. assertFalse(r1.equals(new Double(0.0)));
  88. }
  89. /**
  90. * Two objects that are equal are required to return the same hashCode.
  91. */
  92. @Test
  93. public void testHashCode() {
  94. Range a1 = new Range(1.0, 100.0);
  95. Range a2 = new Range(1.0, 100.0);
  96. assertEquals(a1.hashCode(), a2.hashCode());
  97. a1 = new Range(-100.0, 2.0);
  98. a2 = new Range(-100.0, 2.0);
  99. assertEquals(a1.hashCode(), a2.hashCode());
  100. }
  101. /**
  102. * Simple tests for the contains() method.
  103. */
  104. @Test
  105. public void testContains() {
  106. Range r1 = new Range(0.0, 1.0);
  107. assertFalse(r1.contains(Double.NaN));
  108. assertFalse(r1.contains(Double.NEGATIVE_INFINITY));
  109. assertFalse(r1.contains(-1.0));
  110. assertTrue(r1.contains(0.0));
  111. assertTrue(r1.contains(0.5));
  112. assertTrue(r1.contains(1.0));
  113. assertFalse(r1.contains(2.0));
  114. assertFalse(r1.contains(Double.POSITIVE_INFINITY));
  115. }
  116. /**
  117. * Tests the constrain() method for various values.
  118. */
  119. @Test
  120. public void testConstrain() {
  121. Range r1 = new Range(0.0, 1.0);
  122. double d = r1.constrain(0.5);
  123. assertEquals(0.5, d, 0.0000001);
  124. d = r1.constrain(0.0);
  125. assertEquals(0.0, d, 0.0000001);
  126. d = r1.constrain(1.0);
  127. assertEquals(1.0, d, 0.0000001);
  128. d = r1.constrain(-1.0);
  129. assertEquals(0.0, d, 0.0000001);
  130. d = r1.constrain(2.0);
  131. assertEquals(1.0, d, 0.0000001);
  132. d = r1.constrain(Double.POSITIVE_INFINITY);
  133. assertEquals(1.0, d, 0.0000001);
  134. d = r1.constrain(Double.NEGATIVE_INFINITY);
  135. assertEquals(0.0, d, 0.0000001);
  136. d = r1.constrain(Double.NaN);
  137. assertTrue(Double.isNaN(d));
  138. }
  139. /**
  140. * Simple tests for the intersects() method.
  141. */
  142. @Test
  143. public void testIntersects() {
  144. Range r1 = new Range(0.0, 1.0);
  145. assertFalse(r1.intersects(-2.0, -1.0));
  146. assertFalse(r1.intersects(-2.0, 0.0));
  147. assertTrue(r1.intersects(-2.0, 0.5));
  148. assertTrue(r1.intersects(-2.0, 1.0));
  149. assertTrue(r1.intersects(-2.0, 1.5));
  150. assertTrue(r1.intersects(0.0, 0.5));
  151. assertTrue(r1.intersects(0.0, 1.0));
  152. assertTrue(r1.intersects(0.0, 1.5));
  153. assertTrue(r1.intersects(0.5, 0.6));
  154. assertTrue(r1.intersects(0.5, 1.0));
  155. assertTrue(r1.intersects(0.5, 1.5));
  156. assertFalse(r1.intersects(1.0, 1.1));
  157. assertFalse(r1.intersects(1.5, 2.0));
  158. }
  159. /**
  160. * A simple test for the expand() method.
  161. */
  162. @Test
  163. public void testExpand() {
  164. Range r1 = new Range(0.0, 100.0);
  165. Range r2 = Range.expand(r1, 0.10, 0.10);
  166. assertEquals(-10.0, r2.getLowerBound(), 0.001);
  167. assertEquals(110.0, r2.getUpperBound(), 0.001);
  168. // Expand by 0% does not change the range
  169. r2 = Range.expand(r1, 0.0, 0.0);
  170. assertEquals(r1, r2);
  171. try {
  172. Range.expand(null, 0.1, 0.1);
  173. fail("Null value is accepted");
  174. }
  175. catch (Exception e) {
  176. }
  177. // Lower > upper: mid point is used
  178. r2 = Range.expand(r1, -0.8, -0.5);
  179. assertEquals(65.0, r2.getLowerBound(), 0.001);
  180. assertEquals(65.0, r2.getUpperBound(), 0.001);
  181. }
  182. /**
  183. * A simple test for the scale() method.
  184. */
  185. @Test
  186. public void testShift() {
  187. Range r1 = new Range(10.0, 20.0);
  188. Range r2 = Range.shift(r1, 20.0);
  189. assertEquals(30.0, r2.getLowerBound(), 0.001);
  190. assertEquals(40.0, r2.getUpperBound(), 0.001);
  191. r1 = new Range(0.0, 100.0);
  192. r2 = Range.shift(r1, -50.0, true);
  193. assertEquals(-50.0, r2.getLowerBound(), 0.001);
  194. assertEquals(50.0, r2.getUpperBound(), 0.001);
  195. r1 = new Range(-10.0, 20.0);
  196. r2 = Range.shift(r1, 20.0, true);
  197. assertEquals(10.0, r2.getLowerBound(), 0.001);
  198. assertEquals(40.0, r2.getUpperBound(), 0.001);
  199. r1 = new Range(-10.0, 20.0);
  200. r2 = Range.shift(r1, -30.0, true);
  201. assertEquals(-40.0, r2.getLowerBound(), 0.001);
  202. assertEquals(-10.0, r2.getUpperBound(), 0.001);
  203. r1 = new Range(-10.0, 20.0);
  204. r2 = Range.shift(r1, 20.0, false);
  205. assertEquals(0.0, r2.getLowerBound(), 0.001);
  206. assertEquals(40.0, r2.getUpperBound(), 0.001);
  207. r1 = new Range(-10.0, 20.0);
  208. r2 = Range.shift(r1, -30.0, false);
  209. assertEquals(-40.0, r2.getLowerBound(), 0.001);
  210. assertEquals(0.0, r2.getUpperBound(), 0.001);
  211. // Shifting with a delta of 0 does not change the range
  212. r2 = Range.shift(r1, 0.0);
  213. assertEquals(r1, r2);
  214. try {
  215. Range.shift(null, 0.1);
  216. fail("Null value is accepted");
  217. }
  218. catch (Exception e) {
  219. }
  220. }
  221. /**
  222. * A simple test for the scale() method.
  223. */
  224. @Test
  225. public void testScale() {
  226. Range r1 = new Range(0.0, 100.0);
  227. Range r2 = Range.scale(r1, 0.10);
  228. assertEquals(0.0, r2.getLowerBound(), 0.001);
  229. assertEquals(10.0, r2.getUpperBound(), 0.001);
  230. r1 = new Range(-10.0, 100.0);
  231. r2 = Range.scale(r1, 2.0);
  232. assertEquals(-20.0, r2.getLowerBound(), 0.001);
  233. assertEquals(200.0, r2.getUpperBound(), 0.001);
  234. // Scaling with a factor of 1 does not change the range
  235. r2 = Range.scale(r1, 1.0);
  236. assertEquals(r1, r2);
  237. try {
  238. Range.scale(null, 0.1);
  239. fail("Null value is accepted");
  240. }
  241. catch (Exception e) {
  242. }
  243. try {
  244. Range.scale(r1, -0.5);
  245. fail("Negative factor accepted");
  246. }
  247. catch (Exception e) {
  248. }
  249. }
  250. /**
  251. * Serialize an instance, restore it, and check for equality.
  252. */
  253. @Test
  254. public void testSerialization() {
  255. Range r1 = new Range(25.0, 133.42);
  256. Range r2 = (Range) TestUtilities.serialised(r1);
  257. assertEquals(r1, r2);
  258. }
  259. private static final double EPSILON = 0.0000000001;
  260. /**
  261. * Some checks for the combine method.
  262. */
  263. @Test
  264. public void testCombine() {
  265. Range r1 = new Range(1.0, 2.0);
  266. Range r2 = new Range(1.5, 2.5);
  267. assertNull(Range.combine(null, null));
  268. assertEquals(r1, Range.combine(r1, null));
  269. assertEquals(r2, Range.combine(null, r2));
  270. assertEquals(new Range(1.0, 2.5), Range.combine(r1, r2));
  271. Range r3 = new Range(Double.NaN, 1.3);
  272. Range rr = Range.combine(r1, r3);
  273. assertTrue(Double.isNaN(rr.getLowerBound()));
  274. assertEquals(2.0, rr.getUpperBound(), EPSILON);
  275. Range r4 = new Range(1.7, Double.NaN);
  276. rr = Range.combine(r4, r1);
  277. assertEquals(1.0, rr.getLowerBound(), EPSILON);
  278. assertTrue(Double.isNaN(rr.getUpperBound()));
  279. }
  280. /**
  281. * Some checks for the combineIgnoringNaN() method.
  282. */
  283. @Test
  284. public void testCombineIgnoringNaN() {
  285. Range r1 = new Range(1.0, 2.0);
  286. Range r2 = new Range(1.5, 2.5);
  287. assertNull(Range.combineIgnoringNaN(null, null));
  288. assertEquals(r1, Range.combineIgnoringNaN(r1, null));
  289. assertEquals(r2, Range.combineIgnoringNaN(null, r2));
  290. assertEquals(new Range(1.0, 2.5), Range.combineIgnoringNaN(r1, r2));
  291. Range r3 = new Range(Double.NaN, 1.3);
  292. Range rr = Range.combineIgnoringNaN(r1, r3);
  293. assertEquals(1.0, rr.getLowerBound(), EPSILON);
  294. assertEquals(2.0, rr.getUpperBound(), EPSILON);
  295. Range r4 = new Range(1.7, Double.NaN);
  296. rr = Range.combineIgnoringNaN(r4, r1);
  297. assertEquals(1.0, rr.getLowerBound(), EPSILON);
  298. assertEquals(2.0, rr.getUpperBound(), EPSILON);
  299. }
  300. @Test
  301. public void testIsNaNRange() {
  302. assertTrue(new Range(Double.NaN, Double.NaN).isNaNRange());
  303. assertFalse(new Range(1.0, 2.0).isNaNRange());
  304. assertFalse(new Range(Double.NaN, 2.0).isNaNRange());
  305. assertFalse(new Range(1.0, Double.NaN).isNaNRange());
  306. }
  307. }