SimpleHistogramDatasetTest.java 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  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. * SimpleHistogramDatasetTest.java
  29. * -------------------------------
  30. * (C) Copyright 2005-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. * 10-Jan-2005 : Version 1 (DG);
  38. * 21-May-2007 : Added testClearObservations (DG);
  39. *
  40. */
  41. package org.jfree.data.statistics;
  42. import static org.junit.Assert.assertEquals;
  43. import static org.junit.Assert.assertTrue;
  44. import static org.junit.Assert.assertFalse;
  45. import org.jfree.chart.TestUtilities;
  46. import org.junit.Test;
  47. /**
  48. * Tests for the {@link SimpleHistogramDataset} class.
  49. */
  50. public class SimpleHistogramDatasetTest {
  51. /**
  52. * Ensure that the equals() method can distinguish all fields.
  53. */
  54. @Test
  55. public void testEquals() {
  56. SimpleHistogramDataset d1 = new SimpleHistogramDataset("Dataset 1");
  57. SimpleHistogramDataset d2 = new SimpleHistogramDataset("Dataset 1");
  58. assertTrue(d1.equals(d2));
  59. d1.addBin(new SimpleHistogramBin(1.0, 2.0));
  60. assertFalse(d1.equals(d2));
  61. d2.addBin(new SimpleHistogramBin(1.0, 2.0));
  62. assertTrue(d1.equals(d2));
  63. }
  64. /**
  65. * Some checks for the clone() method.
  66. */
  67. @Test
  68. public void testCloning() throws CloneNotSupportedException {
  69. SimpleHistogramDataset d1 = new SimpleHistogramDataset("Dataset 1");
  70. SimpleHistogramDataset d2 = (SimpleHistogramDataset) d1.clone();
  71. assertTrue(d1 != d2);
  72. assertTrue(d1.getClass() == d2.getClass());
  73. assertTrue(d1.equals(d2));
  74. // check that clone is independent of the original
  75. d2.addBin(new SimpleHistogramBin(2.0, 3.0));
  76. d2.addObservation(2.3);
  77. assertFalse(d1.equals(d2));
  78. }
  79. /**
  80. * Serialize an instance, restore it, and check for equality.
  81. */
  82. @Test
  83. public void testSerialization() {
  84. SimpleHistogramDataset d1 = new SimpleHistogramDataset("D1");
  85. SimpleHistogramDataset d2 = (SimpleHistogramDataset)
  86. TestUtilities.serialised(d1);
  87. assertEquals(d1, d2);
  88. }
  89. private static final double EPSILON = 0.0000000001;
  90. /**
  91. * Some checks for the clearObservations() method.
  92. */
  93. @Test
  94. public void testClearObservations() {
  95. SimpleHistogramDataset d1 = new SimpleHistogramDataset("D1");
  96. d1.clearObservations();
  97. assertEquals(0, d1.getItemCount(0));
  98. d1.addBin(new SimpleHistogramBin(0.0, 1.0));
  99. d1.addObservation(0.5);
  100. assertEquals(1.0, d1.getYValue(0, 0), EPSILON);
  101. }
  102. /**
  103. * Some checks for the removeAllBins() method.
  104. */
  105. @Test
  106. public void testRemoveAllBins() {
  107. SimpleHistogramDataset d1 = new SimpleHistogramDataset("D1");
  108. d1.addBin(new SimpleHistogramBin(0.0, 1.0));
  109. d1.addObservation(0.5);
  110. d1.addBin(new SimpleHistogramBin(2.0, 3.0));
  111. assertEquals(2, d1.getItemCount(0));
  112. d1.removeAllBins();
  113. assertEquals(0, d1.getItemCount(0));
  114. }
  115. }