ClusteredXYBarRendererTest.java 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. /* ===========================================================
  2. * JFreeChart : a free chart library for the Java(tm) platform
  3. * ===========================================================
  4. *
  5. * (C) Copyright 2000-2013, 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. * ClusteredXYBarRendererTest.java
  29. * -------------------------------
  30. * (C) Copyright 2003-2013, by Object Refinery Limited and Contributors.
  31. *
  32. * Original Author: David Gilbert (for Object Refinery Limited);
  33. * Contributor(s): -;
  34. *
  35. * Changes
  36. * -------
  37. * 25-Mar-2003 : Version 1 (DG);
  38. * 22-Oct-2003 : Added hashCode test (DG);
  39. * 10-Jul-2007 : Fixed compile errors (DG);
  40. * 22-Apr-2008 : Added testPublicCloneable() (DG);
  41. *
  42. */
  43. package org.jfree.chart.renderer.xy;
  44. import static org.junit.Assert.assertEquals;
  45. import static org.junit.Assert.assertTrue;
  46. import static org.junit.Assert.assertFalse;
  47. import org.jfree.chart.TestUtilities;
  48. import org.jfree.data.Range;
  49. import org.jfree.data.xy.DefaultIntervalXYDataset;
  50. import org.jfree.data.xy.XYDataset;
  51. import org.jfree.util.PublicCloneable;
  52. import org.junit.Test;
  53. /**
  54. * Tests for the {@link ClusteredXYBarRenderer} class.
  55. */
  56. public class ClusteredXYBarRendererTest {
  57. /**
  58. * Check that the equals() method distinguishes all fields.
  59. */
  60. @Test
  61. public void testEquals() {
  62. ClusteredXYBarRenderer r1 = new ClusteredXYBarRenderer();
  63. ClusteredXYBarRenderer r2 = new ClusteredXYBarRenderer();
  64. assertEquals(r1, r2);
  65. assertEquals(r2, r1);
  66. r1 = new ClusteredXYBarRenderer(1.2, false);
  67. assertFalse(r1.equals(r2));
  68. r2 = new ClusteredXYBarRenderer(1.2, false);
  69. assertTrue(r1.equals(r2));
  70. r1 = new ClusteredXYBarRenderer(1.2, true);
  71. assertFalse(r1.equals(r2));
  72. r2 = new ClusteredXYBarRenderer(1.2, true);
  73. assertTrue(r1.equals(r2));
  74. }
  75. /**
  76. * Two objects that are equal are required to return the same hashCode.
  77. */
  78. @Test
  79. public void testHashcode() {
  80. ClusteredXYBarRenderer r1 = new ClusteredXYBarRenderer();
  81. ClusteredXYBarRenderer r2 = new ClusteredXYBarRenderer();
  82. assertTrue(r1.equals(r2));
  83. int h1 = r1.hashCode();
  84. int h2 = r2.hashCode();
  85. assertEquals(h1, h2);
  86. }
  87. /**
  88. * Confirm that cloning works.
  89. */
  90. @Test
  91. public void testCloning() throws CloneNotSupportedException {
  92. ClusteredXYBarRenderer r1 = new ClusteredXYBarRenderer();
  93. ClusteredXYBarRenderer r2 = (ClusteredXYBarRenderer) r1.clone();
  94. assertTrue(r1 != r2);
  95. assertTrue(r1.getClass() == r2.getClass());
  96. assertTrue(r1.equals(r2));
  97. }
  98. /**
  99. * Verify that this class implements {@link PublicCloneable}.
  100. */
  101. @Test
  102. public void testPublicCloneable() {
  103. ClusteredXYBarRenderer r1 = new ClusteredXYBarRenderer();
  104. assertTrue(r1 instanceof PublicCloneable);
  105. }
  106. /**
  107. * Serialize an instance, restore it, and check for equality.
  108. */
  109. @Test
  110. public void testSerialization() {
  111. ClusteredXYBarRenderer r1 = new ClusteredXYBarRenderer();
  112. ClusteredXYBarRenderer r2 = (ClusteredXYBarRenderer)
  113. TestUtilities.serialised(r1);
  114. assertEquals(r1, r2);
  115. }
  116. private static final double EPSILON = 0.0000000001;
  117. /**
  118. * Some checks for the findDomainBounds() method (which requires special
  119. * handling when the centerBarAtStartValue flag is set to true).
  120. */
  121. @Test
  122. public void testFindDomainBounds() {
  123. AbstractXYItemRenderer renderer = new ClusteredXYBarRenderer();
  124. XYDataset dataset = createSampleDataset1();
  125. Range r = renderer.findDomainBounds(dataset);
  126. assertEquals(0.9, r.getLowerBound(), EPSILON);
  127. assertEquals(13.1, r.getUpperBound(), EPSILON);
  128. renderer = new ClusteredXYBarRenderer(0.0, true);
  129. r = renderer.findDomainBounds(dataset);
  130. assertEquals(0.8, r.getLowerBound(), EPSILON);
  131. assertEquals(13.0, r.getUpperBound(), EPSILON);
  132. // check that a null dataset returns null bounds
  133. assertTrue(renderer.findDomainBounds(null) == null);
  134. }
  135. /**
  136. * Creates a sample dataset for testing.
  137. *
  138. * @return A sample dataset.
  139. */
  140. public DefaultIntervalXYDataset createSampleDataset1() {
  141. DefaultIntervalXYDataset d = new DefaultIntervalXYDataset();
  142. double[] x1 = new double[] {1.0, 2.0, 3.0};
  143. double[] x1Start = new double[] {0.9, 1.9, 2.9};
  144. double[] x1End = new double[] {1.1, 2.1, 3.1};
  145. double[] y1 = new double[] {4.0, 5.0, 6.0};
  146. double[] y1Start = new double[] {1.09, 2.09, 3.09};
  147. double[] y1End = new double[] {1.11, 2.11, 3.11};
  148. double[][] data1 = new double[][] {x1, x1Start, x1End, y1, y1Start,
  149. y1End};
  150. d.addSeries("S1", data1);
  151. double[] x2 = new double[] {11.0, 12.0, 13.0};
  152. double[] x2Start = new double[] {10.9, 11.9, 12.9};
  153. double[] x2End = new double[] {11.1, 12.1, 13.1};
  154. double[] y2 = new double[] {14.0, 15.0, 16.0};
  155. double[] y2Start = new double[] {11.09, 12.09, 13.09};
  156. double[] y2End = new double[] {11.11, 12.11, 13.11};
  157. double[][] data2 = new double[][] {x2, x2Start, x2End, y2, y2Start,
  158. y2End};
  159. d.addSeries("S2", data2);
  160. return d;
  161. }
  162. }