File path: /jfreechart-1.0.10/tests/org/jfree/data/xy/junit/VectorSeriesTests.java | File path: /jfreechart-1.0.10/tests/org/jfree/data/xy/junit/XIntervalSeriesTests.java | |||
Method name: void testEquals()
|
Method name: void testEquals()
|
|||
Number of AST nodes: 27 | Number of AST nodes: 27 | |||
1 | VectorSeries s1 = new VectorSeries("s1");↵ | 1 | XIntervalSeries s1 = new XIntervalSeries("s1");↵ | |
2 | VectorSeries s2 = new VectorSeries("s1");↵ | 2 | XIntervalSeries s2 = new XIntervalSeries("s1");↵ | |
3 | assertTrue(s1.equals(s2));↵ | 3 | assertTrue(s1.equals(s2));↵ | |
4 | ↵ | |||
5 | // seriesKey↵ | 4 | // seriesKey↵ | |
6 | s1 = new VectorSeries("s2");↵ | 5 | s1 = new XIntervalSeries("s2");↵ | |
7 | assertFalse(s1.equals(s2));↵ | 6 | assertFalse(s1.equals(s2));↵ | |
8 | s2 = new VectorSeries("s2");↵ | 7 | s2 = new XIntervalSeries("s2");↵ | |
9 | assertTrue(s1.equals(s2));↵ | 8 | assertTrue(s1.equals(s2));↵ | |
10 | ↵ | |||
11 | // autoSort↵ | 9 | // autoSort↵ | |
12 | s1 = new VectorSeries("s2", true, true);↵ | 10 | s1 = new XIntervalSeries("s2", false, true);↵ | |
13 | assertFalse(s1.equals(s2));↵ | 11 | assertFalse(s1.equals(s2));↵ | |
14 | s2 = new VectorSeries("s2", true, true);↵ | 12 | s2 = new XIntervalSeries("s2", false, true);↵ | |
15 | assertTrue(s1.equals(s2));↵ | 13 | assertTrue(s1.equals(s2));↵ | |
16 | ↵ | |||
17 | // allowDuplicateValues↵ | 14 | // allowDuplicateValues↵ | |
18 | s1 = new VectorSeries("s2", false, false);↵ | 15 | s1 = new XIntervalSeries("s2", false, false);↵ | |
19 | assertFalse(s1.equals(s2));↵ | 16 | assertFalse(s1.equals(s2));↵ | |
20 | s2 = new VectorSeries("s2", false, false);↵ | 17 | s2 = new XIntervalSeries("s2", false, false);↵ | |
21 | assertTrue(s1.equals(s2));↵ | 18 | assertTrue(s1.equals(s2));↵ | |
22 | ↵ | |||
23 | // add a value↵ | 19 | // add a value↵ | |
24 | s1.add(1.0, 0.5, 1.5, 2.0);↵ | 20 | s1.add(1.0, 0.5, 1.5, 2.0);↵ | |
25 | assertFalse(s1.equals(s2));↵ | 21 | assertFalse(s1.equals(s2));↵ | |
26 | s2.add(1.0, 0.5, 1.5, 2.0);↵ | 22 | s2.add(1.0, 0.5, 1.5, 2.0);↵ | |
27 | assertTrue(s2.equals(s1));↵ | 23 | assertTrue(s2.equals(s1));↵ | |
28 | // add another value↵ | 24 | // add another value↵ | |
29 | s1.add(2.0, 0.5, 1.5, 2.0);↵ | 25 | s1.add(2.0, 0.5, 1.5, 2.0);↵ | |
30 | assertFalse(s1.equals(s2));↵ | 26 | assertFalse(s1.equals(s2));↵ | |
31 | s2.add(2.0, 0.5, 1.5, 2.0);↵ | 27 | s2.add(2.0, 0.5, 1.5, 2.0);↵ | |
32 | assertTrue(s2.equals(s1));↵ | 28 | assertTrue(s2.equals(s1));↵ | |
33 | // remove a value↵ | 29 | // remove a value↵ | |
34 | s1.remove(new XYCoordinate(1.0, 0.5));↵ | 30 | s1.remove(new Double(1.0));↵ | |
35 | assertFalse(s1.equals(s2));↵ | 31 | assertFalse(s1.equals(s2));↵ | |
36 | s2.remove(new XYCoordinate(1.0, 0.5));↵ | 32 | s2.remove(new Double(1.0));↵ | |
37 | assertTrue(s2.equals(s1)); | 33 |
| |
See real code fragment | See real code fragment |
Number of common nesting structure subtrees | 1 |
Number of refactorable cases | 0 |
Number of non-refactorable cases | 1 |
Time elapsed for finding largest common nesting structure subtrees (ms) | 0.0 |
Clones location | Clones are in different classes having the same super class |
Number of node comparisons | 209 |
Number of mapped statements | 25 |
Number of unmapped statements in the first code fragment | 2 |
Number of unmapped statements in the second code fragment | 2 |
Time elapsed for statement mapping (ms) | 0.0 |
Clone type | Type 2 |
ID | Statement | ID | Statement | |||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
1 | VectorSeries s1 = new VectorSeries("s1"); |
| 1 | XIntervalSeries s1 = new XIntervalSeries("s1"); | ||||||||||||||||
2 | VectorSeries s2 = new VectorSeries("s1"); |
| 2 | XIntervalSeries s2 = new XIntervalSeries("s1"); | ||||||||||||||||
3 | assertTrue(s1.equals(s2)); |
| 3 | assertTrue(s1.equals(s2)); | ||||||||||||||||
4 | s1 = new VectorSeries("s2"); |
| 4 | s1 = new XIntervalSeries("s2"); | ||||||||||||||||
5 | assertFalse(s1.equals(s2)); |
| 5 | assertFalse(s1.equals(s2)); | ||||||||||||||||
6 | s2 = new VectorSeries("s2"); |
| 6 | s2 = new XIntervalSeries("s2"); | ||||||||||||||||
7 | assertTrue(s1.equals(s2)); |
| 7 | assertTrue(s1.equals(s2)); | ||||||||||||||||
8 | s1 = new VectorSeries("s2", true, true); |
| 8 | s1 = new XIntervalSeries("s2", false, true); | ||||||||||||||||
9 | assertFalse(s1.equals(s2)); |
| 9 | assertFalse(s1.equals(s2)); | ||||||||||||||||
10 | s2 = new VectorSeries("s2", true, true); |
| 10 | s2 = new XIntervalSeries("s2", false, true); | ||||||||||||||||
11 | assertTrue(s1.equals(s2)); |
| 11 | assertTrue(s1.equals(s2)); | ||||||||||||||||
12 | s1 = new VectorSeries("s2", false, false); |
| 12 | s1 = new XIntervalSeries("s2", false, false); | ||||||||||||||||
13 | assertFalse(s1.equals(s2)); |
| 13 | assertFalse(s1.equals(s2)); | ||||||||||||||||
14 | s2 = new VectorSeries("s2", false, false); |
| 14 | s2 = new XIntervalSeries("s2", false, false); | ||||||||||||||||
15 | assertTrue(s1.equals(s2)); |
| 15 | assertTrue(s1.equals(s2)); | ||||||||||||||||
16 | s1.add(1.0, 0.5, 1.5, 2.0); |
| 16 | s1.add(1.0, 0.5, 1.5, 2.0); | ||||||||||||||||
17 | assertFalse(s1.equals(s2)); |
| 17 | assertFalse(s1.equals(s2)); | ||||||||||||||||
18 | s2.add(1.0, 0.5, 1.5, 2.0); |
| 18 | s2.add(1.0, 0.5, 1.5, 2.0); | ||||||||||||||||
19 | assertTrue(s2.equals(s1)); |
| 19 | assertTrue(s2.equals(s1)); | ||||||||||||||||
20 | s1.add(2.0, 0.5, 1.5, 2.0); |
| 20 | s1.add(2.0, 0.5, 1.5, 2.0); | ||||||||||||||||
21 | assertFalse(s1.equals(s2)); |
| 21 | assertFalse(s1.equals(s2)); | ||||||||||||||||
22 | s2.add(2.0, 0.5, 1.5, 2.0); |
| 22 | s2.add(2.0, 0.5, 1.5, 2.0); | ||||||||||||||||
23 | assertTrue(s2.equals(s1)); |
| 23 | assertTrue(s2.equals(s1)); | ||||||||||||||||
|
| 24 | s1.remove(new Double(1.0)); | |||||||||||||||||
24 | s1.remove(new XYCoordinate(1.0, 0.5)); |
| | |||||||||||||||||
25 | assertFalse(s1.equals(s2)); |
| 25 | assertFalse(s1.equals(s2)); | ||||||||||||||||
|
| 26 | s2.remove(new Double(1.0)); | |||||||||||||||||
26 | s2.remove(new XYCoordinate(1.0, 0.5)); |
| | |||||||||||||||||
27 | assertTrue(s2.equals(s1)); |
| 27 | assertTrue(s2.equals(s1)); |
Row | Violation |
---|---|
1 | Expression s1 cannot be unified with expression s1 , because common superclass org.jfree.data.ComparableObjectSeries does not declare member(s) public void add(double, double, double, double) |
2 | Expression s2 cannot be unified with expression s2 , because common superclass org.jfree.data.ComparableObjectSeries does not declare member(s) public void add(double, double, double, double) |
3 | Expression s1 cannot be unified with expression s1 , because common superclass org.jfree.data.ComparableObjectSeries does not declare member(s) public void add(double, double, double, double) |
4 | Expression s2 cannot be unified with expression s2 , because common superclass org.jfree.data.ComparableObjectSeries does not declare member(s) public void add(double, double, double, double) |
5 | Unmatched statement s1.remove(new Double(1.0)); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
6 | Unmatched statement s1.remove(new XYCoordinate(1.0,0.5)); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
7 | Unmatched statement s2.remove(new Double(1.0)); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
8 | Unmatched statement s2.remove(new XYCoordinate(1.0,0.5)); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
9 | Clone fragment #1 returns variables s1, s2 , while Clone fragment #2 returns variables s1, s2 |