ThroughputController sub_1 = new ThroughputController(); sub_1.setStyle(ThroughputController.BYPERCENT); sub_1.setPercentThroughput(33.33f); sub_1.addTestElement(new TestSampler("one")); sub_1.addTestElement(new TestSampler("two")); LoopController controller = new LoopController(); controller.setLoops(6); controller.addTestElement(new TestSampler("zero")); controller.addTestElement(sub_1); controller.addIterationListener(sub_1); controller.addTestElement(new TestSampler("three")); // Expected results established using the DDA // algorithm (see // http://www.siggraph.org/education/materials/HyperGraph/scanline/outprims/drawline.htm): String[] order = new String[] { "zero", // 0/1 vs. 1/1 -> 0 is // closer to 33.33 "three", "zero", // 0/2 vs. 1/2 -> 50.0 is closer to // 33.33 "one", "two", "three", "zero", // 1/3 vs. 2/3 -> 33.33 is // closer to 33.33 "three", "zero", // 1/4 vs. 2/4 -> 25.0 is closer to // 33.33 "three", "zero", // 1/5 vs. 2/5 -> 40.0 is closer to // 33.33 "one", "two", "three", "zero", // 2/6 vs. 3/6 -> 33.33 is // closer to 33.33 "three", // etc... }; int counter = 0; controller.setRunningVersion(true); sub_1.setRunningVersion(true); sub_1.testStarted(); controller.initialize(); for (int i = 0; i < 3; i++) { TestElement sampler = null; while ((sampler = controller.next()) != null) { assertEquals("Counter: " + counter + ", i: " + i, order[counter], sampler.getName()); counter++; } assertEquals(counter, order.length); counter = 0; } sub_1.testEnded();
ThroughputController sub_1 = new ThroughputController(); sub_1.setStyle(ThroughputController.BYPERCENT); sub_1.setPercentThroughput(0.0f); sub_1.addTestElement(new TestSampler("one")); sub_1.addTestElement(new TestSampler("two")); LoopController controller = new LoopController(); controller.setLoops(150); controller.addTestElement(new TestSampler("zero")); controller.addTestElement(sub_1); controller.addIterationListener(sub_1); controller.addTestElement(new TestSampler("three")); String[] order = new String[] { "zero", "three", }; int counter = 0; controller.setRunningVersion(true); sub_1.setRunningVersion(true); sub_1.testStarted(); controller.initialize(); for (int i = 0; i < 3; i++) { TestElement sampler = null; while ((sampler = controller.next()) != null) { assertEquals("Counter: " + counter + ", i: " + i, order[counter % order.length], sampler.getName()); counter++; } assertEquals(counter, 150 * order.length); counter = 0; } sub_1.testEnded();
Clone fragments detected by clone detection tool
File path: /jakarta-jmeter-2.3.2/test/src/org/apache/jmeter/control/TestThroughputController.java File path: /jakarta-jmeter-2.3.2/test/src/org/apache/jmeter/control/TestThroughputController.java
Method name: void testByPercent33() Method name: void testByPercentZero()
Number of AST nodes: 25 Number of AST nodes: 25
1
ThroughputController sub_1 = new ThroughputController();
1
ThroughputController sub_1 = new ThroughputController();
2
			sub_1.setStyle(ThroughputController.BYPERCENT);
2
			sub_1.setStyle(ThroughputController.BYPERCENT);
3
			sub_1.setPercentThroughput(33.33f);
3
			sub_1.setPercentThroughput(0.0f);
4
			sub_1.addTestElement(new TestSampler("one"));
4
			sub_1.addTestElement(new TestSampler("one"));
5
			sub_1.addTestElement(new TestSampler("two"));
5
			sub_1.addTestElement(new TestSampler("two"));
6
			LoopController controller = new LoopController();
6
			LoopController controller = new LoopController();
7
			controller.setLoops(6);
7
			controller.setLoops(150);
8
			controller.addTestElement(new TestSampler("zero"));
8
			controller.addTestElement(new TestSampler("zero"));
9
			controller.addTestElement(sub_1);
9
			controller.addTestElement(sub_1);
10
			controller.addIterationListener(sub_1);
10
			controller.addIterationListener(sub_1);
11
			controller.addTestElement(new TestSampler("three"));
11
			controller.addTestElement(new TestSampler("three"));
12
			// Expected results established using the DDA
13
			// algorithm (see
14
			// http://www.siggraph.org/education/materials/HyperGraph/scanline/outprims/drawline.htm):
15
			String[] order = new String[] { "zero", // 0/1 vs. 1/1 -> 0 is
16
													// closer to 33.33
17
					"three", "zero", // 0/2 vs. 1/2 -> 50.0 is closer to
18
										// 33.33
19
					"one", "two", "three", "zero", // 1/3 vs. 2/3 -> 33.33 is
20
													// closer to 33.33
21
					"three", "zero", // 1/4 vs. 2/4 -> 25.0 is closer to
22
										// 33.33
23
					"three", "zero", // 1/5 vs. 2/5 -> 40.0 is closer to
24
										// 33.33
25
					"one", "two", "three", "zero", // 2/6 vs. 3/6 -> 33.33 is
26
													// closer to 33.33
27
					"three",
28
			// etc...
29
			
30
};
12
			String[] order = new String[] { "zero", "three", };
31
			int counter = 0;
13
			int counter = 0;
32
			controller.setRunningVersion(true);
14
			controller.setRunningVersion(true);
33
			sub_1.setRunningVersion(true);
15
			sub_1.setRunningVersion(true);
34
			sub_1.testStarted();
16
			sub_1.testStarted();
35
			controller.initialize();
17
			controller.initialize();
36
			for (int i = 0; i < 3; i++) {
18
			for (int i = 0; i < 3; i++) {
37
				TestElement sampler = null;
19
				TestElement sampler = null;
38
				while ((sampler = controller.next()) != null) {
20
				while ((sampler = controller.next()) != null) {
39
					assertEquals("Counter: " + counter + ", i: " + i, order[counter], sampler.getName());
21
					assertEquals("Counter: " + counter + ", i: " + i, order[counter % order.length], sampler.getName());
40
					counter++;
22
					counter++;
41
				}
23
				}
42
				assertEquals(counter, order.length);
24
				assertEquals(counter, 150 * order.length);
43
				counter = 0;
25
				counter = 0;
44
			}
26
			}
45
			sub_1.testEnded();
27
			sub_1.testEnded();
Summary
Number of common nesting structure subtrees1
Number of refactorable cases0
Number of non-refactorable cases1
Time elapsed for finding largest common nesting structure subtrees (ms)0.4
Clones locationClones are declared in the same class
Number of node comparisons172
  1. {Non-refactorable}
    Mapping Summary
    Number of mapped statements25
    Number of unmapped statements in the first code fragment0
    Number of unmapped statements in the second code fragment0
    Time elapsed for statement mapping (ms)34.9
    Clone typeType 2
    Mapped Statements
    ID Statement ID Statement
    1
    ThroughputController sub_1 = new ThroughputController();
    1
    ThroughputController sub_1 = new ThroughputController();
    2
    sub_1.setStyle(ThroughputController.BYPERCENT);
    2
    sub_1.setStyle(ThroughputController.BYPERCENT);
    3
    sub_1.setPercentThroughput(33.33f);
    3
    sub_1.setPercentThroughput(33.33f);
    3
    sub_1.setPercentThroughput(0.0f);
    Differences
    Expression1Expression2Difference
    33.33f0.0fLITERAL_VALUE_MISMATCH
    3
    sub_1.setPercentThroughput(0.0f);
    4
    sub_1.addTestElement(new TestSampler("one"));
    4
    sub_1.addTestElement(new TestSampler("one"));
    5
    sub_1.addTestElement(new TestSampler("two"));
    5
    sub_1.addTestElement(new TestSampler("two"));
    6
    LoopController controller = new LoopController();
    6
    LoopController controller = new LoopController();
    7
    controller.setLoops(6);
    7
    controller.setLoops(6);
    7
    controller.setLoops(150);
    Differences
    Expression1Expression2Difference
    6150LITERAL_VALUE_MISMATCH
    7
    controller.setLoops(150);
    8
    controller.addTestElement(new TestSampler("zero"));
    8
    controller.addTestElement(new TestSampler("zero"));
    9
    controller.addTestElement(sub_1);
    9
    controller.addTestElement(sub_1);
    10
    controller.addIterationListener(sub_1);
    10
    controller.addIterationListener(sub_1);
    11
    controller.addTestElement(new TestSampler("three"));
    11
    controller.addTestElement(new TestSampler("three"));
    12
    String[] order = new String[] {"zero", "three", "zero", "one", "two", "three", "zero", "three", "zero", "three", "zero", "one", "two", "three", "zero", "three"};
    12
    String[] order = new String[] {"zero", "three", "zero", "one", "two", "three", "zero", "three", "zero", "three", "zero", "one", "two", "three", "zero", "three"};
    12
    String[] order = new String[] {"zero", "three"};
    Differences
    Expression1Expression2Difference
    {"zero","three","zero","one","two","three","zero","three","zero","three","zero","one","two","three","zero","three"}{"zero","three"}ARRAY_INITIALIZER_EXPRESSION_NUMBER_MISMATCH
    12
    String[] order = new String[] {"zero", "three"};
    13
    int counter = 0;
    13
    int counter = 0;
    14
    controller.setRunningVersion(true);
    14
    controller.setRunningVersion(true);
    15
    sub_1.setRunningVersion(true);
    15
    sub_1.setRunningVersion(true);
    16
    sub_1.testStarted();
    16
    sub_1.testStarted();
    17
    controller.initialize();
    17
    controller.initialize();
    18
    for (int i = 0; i < 3; i++)
    18
    for (int i = 0; i < 3; i++)
    19
    TestElement sampler = null;
    19
    TestElement sampler = null;
    20
    while ((sampler = controller.next()) != null)
    20
    while ((sampler = controller.next()) != null)
    21
    assertEquals("Counter: " + counter + ", i: " + i, order[counter], sampler.getName());
    21
    assertEquals("Counter: " + counter + ", i: " + i, order[counter], sampler.getName());
    21
    assertEquals("Counter: " + counter + ", i: " + i, order[counter % order.length], sampler.getName());
    Differences
    Expression1Expression2Difference
    countercounter % order.lengthTYPE_COMPATIBLE_REPLACEMENT
    Preondition Violations
    Expression counter cannot be parameterized, because it has dependencies to/from statements that will be extracted
    Expression counter % order.length cannot be parameterized, because it has dependencies to/from statements that will be extracted
    21
    assertEquals("Counter: " + counter + ", i: " + i, order[counter % order.length], sampler.getName());
    22
    counter++;
    22
    counter++;
    23
    assertEquals(counter, order.length);
    23
    assertEquals(counter, order.length);
    23
    assertEquals(counter, 150 * order.length);
    Differences
    Expression1Expression2Difference
    order.length150 * order.lengthTYPE_COMPATIBLE_REPLACEMENT
    Preondition Violations
    Expression order.length cannot be parameterized, because it has dependencies to/from statements that will be extracted
    Expression 150 * order.length cannot be parameterized, because it has dependencies to/from statements that will be extracted
    23
    assertEquals(counter, 150 * order.length);
    24
    counter = 0;
    24
    counter = 0;
    25
    sub_1.testEnded();
    25
    sub_1.testEnded();
    Precondition Violations (4)
    Row Violation
    1Expression counter cannot be parameterized, because it has dependencies to/from statements that will be extracted
    2Expression counter % order.length cannot be parameterized, because it has dependencies to/from statements that will be extracted
    3Expression order.length cannot be parameterized, because it has dependencies to/from statements that will be extracted
    4Expression 150 * order.length cannot be parameterized, because it has dependencies to/from statements that will be extracted