aboutsummaryrefslogtreecommitdiffstats
path: root/it/it-tests
diff options
context:
space:
mode:
authorJulien Lancelot <julien.lancelot@sonarsource.com>2015-11-13 17:41:30 +0100
committerJulien Lancelot <julien.lancelot@sonarsource.com>2015-11-16 08:44:16 +0100
commit2b676da5ab6265e66534b735e82fcdfc7f32bb10 (patch)
tree4704c3dde7c088b04826350120df055f62691741 /it/it-tests
parent1757a06de3e2196b15cf0656b3aa844ea729d6e3 (diff)
downloadsonarqube-2b676da5ab6265e66534b735e82fcdfc7f32bb10.tar.gz
sonarqube-2b676da5ab6265e66534b735e82fcdfc7f32bb10.zip
SONAR-6323 Replace java project by xoo project in DuplicationsTest
Diffstat (limited to 'it/it-tests')
-rw-r--r--it/it-tests/src/test/java/it/Category4Suite.java1
-rw-r--r--it/it-tests/src/test/java/it/duplication/DuplicationsTest.java237
-rw-r--r--it/it-tests/src/test/resources/duplication/DuplicationsTest/duplications_show-expected.json26
-rw-r--r--it/it-tests/src/test/resources/duplication/DuplicationsTest/sources_lines_duplication-expected.json359
4 files changed, 502 insertions, 121 deletions
diff --git a/it/it-tests/src/test/java/it/Category4Suite.java b/it/it-tests/src/test/java/it/Category4Suite.java
index 9a566c5741c..c1460fc9218 100644
--- a/it/it-tests/src/test/java/it/Category4Suite.java
+++ b/it/it-tests/src/test/java/it/Category4Suite.java
@@ -69,6 +69,5 @@ public class Category4Suite {
@ClassRule
public static final Orchestrator ORCHESTRATOR = Orchestrator.builderEnv()
.addPlugin(xooPlugin())
- .setOrchestratorProperty("javaVersion", "LATEST_RELEASE").addPlugin("java")
.build();
}
diff --git a/it/it-tests/src/test/java/it/duplication/DuplicationsTest.java b/it/it-tests/src/test/java/it/duplication/DuplicationsTest.java
index a800174764a..729bc564e00 100644
--- a/it/it-tests/src/test/java/it/duplication/DuplicationsTest.java
+++ b/it/it-tests/src/test/java/it/duplication/DuplicationsTest.java
@@ -1,155 +1,107 @@
/*
- * Copyright (C) 2009-2014 SonarSource SA
- * All rights reserved
+ * SonarQube, open source software quality management tool.
+ * Copyright (C) 2008-2014 SonarSource
* mailto:contact AT sonarsource DOT com
+ *
+ * SonarQube is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * SonarQube is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
+
package it.duplication;
import com.sonar.orchestrator.Orchestrator;
-import com.sonar.orchestrator.build.MavenBuild;
+import com.sonar.orchestrator.locator.FileLocation;
import it.Category4Suite;
+import java.util.List;
+import org.apache.commons.io.IOUtils;
+import org.apache.commons.lang3.ArrayUtils;
import org.junit.BeforeClass;
import org.junit.ClassRule;
import org.junit.Test;
+import org.sonar.wsclient.issue.Issue;
+import org.sonar.wsclient.issue.IssueQuery;
import org.sonar.wsclient.services.Resource;
import org.sonar.wsclient.services.ResourceQuery;
-import util.ItUtils;
-import static org.hamcrest.Matchers.is;
-import static org.hamcrest.core.IsNot.not;
-import static org.hamcrest.core.IsNull.nullValue;
-import static org.junit.Assert.assertThat;
+import static org.assertj.core.api.Assertions.assertThat;
+import static org.skyscreamer.jsonassert.JSONAssert.assertEquals;
+import static util.ItUtils.runProjectAnalysis;
+import static util.ItUtils.setServerProperty;
public class DuplicationsTest {
- private static final String DUPLICATIONS = "com.sonarsource.it.samples:duplications";
- private static final String DUPLICATIONS_WITH_EXCLUSIONS = "com.sonarsource.it.samples:duplications-with-exclusions";
+ static final String DUPLICATIONS = "file-duplications";
+ static final String DUPLICATIONS_WITH_EXCLUSIONS = "file-duplications-with-exclusions";
+ static final String WITHOUT_ENOUGH_TOKENS = "project_without_enough_tokens";
@ClassRule
public static Orchestrator orchestrator = Category4Suite.ORCHESTRATOR;
@BeforeClass
- public static void init() {
+ public static void analyzeProjects() {
orchestrator.resetData();
- MavenBuild build = MavenBuild.create(ItUtils.projectPom("duplications/file-duplications"))
- .setCleanPackageSonarGoals();
- orchestrator.executeBuild(build);
-
- // Use a new project key to avoid conflict with other tests
- String projectKey = DUPLICATIONS_WITH_EXCLUSIONS;
- build = MavenBuild.create(ItUtils.projectPom("duplications/file-duplications"))
- .setCleanPackageSonarGoals()
- .setProperties("sonar.projectKey", projectKey,
- "sonar.cpd.exclusions", "**/Class*");
- orchestrator.executeBuild(build);
+ orchestrator.getServer().restoreProfile(FileLocation.ofClasspath("/duplication/xoo-duplication-profile.xml"));
+ analyzeProject(DUPLICATIONS);
+ analyzeProject(DUPLICATIONS_WITH_EXCLUSIONS, "sonar.cpd.exclusions", "**/File*");
+ // Set minimum tokens to a big value in order to not get duplications
+ setServerProperty(orchestrator, "sonar.cpd.xoo.minimumTokens", "1000");
+ analyzeProject(WITHOUT_ENOUGH_TOKENS);
}
@Test
- public void duplicated_lines_within_same_class() {
- Resource file = getResource(DUPLICATIONS + ":src/main/java/duplicated_lines_within_same_class/DuplicatedLinesInSameClass.java");
- assertThat(file, not(nullValue()));
- assertThat(file.getMeasureValue("duplicated_blocks"), is(2.0));
- assertThat(file.getMeasureValue("duplicated_lines"), is(27.0 * 2)); // 2 blocks with 27 lines
- assertThat(file.getMeasureValue("duplicated_files"), is(1.0));
- assertThat(file.getMeasureValue("duplicated_lines_density"), is(60.0));
+ public void duplicated_lines_within_same_file() {
+ verifyDuplicationMeasures(DUPLICATIONS + ":src/main/xoo/duplicated_lines_within_same_file/DuplicatedLinesInSameFile.xoo",
+ 2,
+ 30 * 2, // 2 blocks with 30 lines
+ 1,
+ 84.5);
}
@Test
public void duplicated_same_lines_within_3_classes() {
- Resource file1 = getResource(DUPLICATIONS + ":src/main/java/duplicated_same_lines_within_3_classes/Class1.java");
- assertThat(file1, not(nullValue()));
- assertThat(file1.getMeasureValue("duplicated_blocks"), is(1.0));
- assertThat(file1.getMeasureValue("duplicated_lines"), is(29.0));
- assertThat(file1.getMeasureValue("duplicated_files"), is(1.0));
- assertThat(file1.getMeasureValue("duplicated_lines_density"), is(47.5));
-
- Resource file2 = getResource(DUPLICATIONS + ":src/main/java/duplicated_same_lines_within_3_classes/Class2.java");
- assertThat(file2, not(nullValue()));
- assertThat(file2.getMeasureValue("duplicated_blocks"), is(1.0));
- assertThat(file2.getMeasureValue("duplicated_lines"), is(29.0));
- assertThat(file2.getMeasureValue("duplicated_files"), is(1.0));
- assertThat(file2.getMeasureValue("duplicated_lines_density"), is(48.3));
-
- Resource file3 = getResource(DUPLICATIONS + ":src/main/java/duplicated_same_lines_within_3_classes/Class3.java");
- assertThat(file3, not(nullValue()));
- assertThat(file3.getMeasureValue("duplicated_blocks"), is(1.0));
- assertThat(file3.getMeasureValue("duplicated_lines"), is(29.0));
- assertThat(file3.getMeasureValue("duplicated_files"), is(1.0));
- assertThat(file3.getMeasureValue("duplicated_lines_density"), is(46.0));
-
- Resource pkg = getResource(DUPLICATIONS + ":src/main/java/duplicated_same_lines_within_3_classes");
- assertThat(pkg, not(nullValue()));
- assertThat(pkg.getMeasureValue("duplicated_blocks"), is(3.0));
- assertThat(pkg.getMeasureValue("duplicated_lines"), is(29.0 * 3)); // 3 blocks with 29 lines
- assertThat(pkg.getMeasureValue("duplicated_files"), is(3.0));
- assertThat(pkg.getMeasureValue("duplicated_lines_density"), is(47.3));
+ verifyDuplicationMeasures(DUPLICATIONS + ":src/main/xoo/duplicated_same_lines_within_3_files/File1.xoo", 1, 33, 1, 78.6);
+ verifyDuplicationMeasures(DUPLICATIONS + ":src/main/xoo/duplicated_same_lines_within_3_files/File2.xoo", 1, 31, 1, 75.6);
+ verifyDuplicationMeasures(DUPLICATIONS + ":src/main/xoo/duplicated_same_lines_within_3_files/File3.xoo", 1, 31, 1, 70.5);
+ verifyDuplicationMeasures(DUPLICATIONS + ":src/main/xoo/duplicated_same_lines_within_3_files", 3, 95, 3, 74.8);
+ }
+
+ @Test
+ public void duplicated_lines_within_directory() {
+ verifyDuplicationMeasures(DUPLICATIONS + ":src/main/xoo/duplicated_lines_within_dir/DuplicatedLinesInSameDirectory1.xoo", 1, 30, 1, 28.3);
+ verifyDuplicationMeasures(DUPLICATIONS + ":src/main/xoo/duplicated_lines_within_dir/DuplicatedLinesInSameDirectory2.xoo", 1, 30, 1, 41.7);
+ verifyDuplicationMeasures(DUPLICATIONS + ":src/main/xoo/duplicated_lines_within_dir", 2, 60, 2, 33.7);
}
@Test
- public void duplicated_lines_within_package() {
- Resource file1 = getResource(DUPLICATIONS + ":src/main/java/duplicated_lines_within_package/DuplicatedLinesInSamePackage1.java");
- assertThat(file1, not(nullValue()));
- assertThat(file1.getMeasureValue("duplicated_blocks"), is(4.0));
- assertThat(file1.getMeasureValue("duplicated_lines"), is(72.0));
- assertThat(file1.getMeasureValue("duplicated_files"), is(1.0));
- assertThat(file1.getMeasureValue("duplicated_lines_density"), is(58.1));
-
- Resource file2 = getResource(DUPLICATIONS + ":src/main/java/duplicated_lines_within_package/DuplicatedLinesInSamePackage2.java");
- assertThat(file2, not(nullValue()));
- assertThat(file2.getMeasureValue("duplicated_blocks"), is(3.0));
- assertThat(file2.getMeasureValue("duplicated_lines"), is(58.0));
- assertThat(file2.getMeasureValue("duplicated_files"), is(1.0));
- assertThat(file2.getMeasureValue("duplicated_lines_density"), is(64.4));
-
- Resource pkg = getResource(DUPLICATIONS + ":src/main/java/duplicated_lines_within_package");
- assertThat(pkg, not(nullValue()));
- assertThat(pkg.getMeasureValue("duplicated_blocks"), is(4.0 + 3.0));
- assertThat(pkg.getMeasureValue("duplicated_lines"), is(72.0 + 58.0));
- assertThat(pkg.getMeasureValue("duplicated_files"), is(2.0));
- assertThat(pkg.getMeasureValue("duplicated_lines_density"), is(60.7));
+ public void duplicated_lines_with_other_directory() {
+ verifyDuplicationMeasures(DUPLICATIONS + ":src/main/xoo/duplicated_lines_with_other_dir1/DuplicatedLinesWithOtherDirectory.xoo", 1, 39, 1, 92.9);
+ verifyDuplicationMeasures(DUPLICATIONS + ":src/main/xoo/duplicated_lines_with_other_dir1", 1, 39, 1, 92.9);
+
+ verifyDuplicationMeasures(DUPLICATIONS + ":src/main/xoo/duplicated_lines_with_other_dir2/DuplicatedLinesWithOtherDirectory.xoo", 1, 39, 1, 92.9);
+ verifyDuplicationMeasures(DUPLICATIONS + ":src/main/xoo/duplicated_lines_with_other_dir2", 1, 39, 1, 92.9);
}
@Test
- public void duplicated_lines_with_other_package() {
- Resource file1 = getResource(DUPLICATIONS + ":src/main/java/duplicated_lines_with_other_package1/DuplicatedLinesWithOtherPackage.java");
- assertThat(file1, not(nullValue()));
- assertThat(file1.getMeasureValue("duplicated_blocks"), is(1.0));
- assertThat(file1.getMeasureValue("duplicated_lines"), is(36.0));
- assertThat(file1.getMeasureValue("duplicated_files"), is(1.0));
- assertThat(file1.getMeasureValue("duplicated_lines_density"), is(60.0));
-
- Resource pkg1 = getResource(DUPLICATIONS + ":src/main/java/duplicated_lines_with_other_package1");
- assertThat(pkg1, not(nullValue()));
- assertThat(pkg1.getMeasureValue("duplicated_blocks"), is(1.0));
- assertThat(pkg1.getMeasureValue("duplicated_lines"), is(36.0));
- assertThat(pkg1.getMeasureValue("duplicated_files"), is(1.0));
- assertThat(pkg1.getMeasureValue("duplicated_lines_density"), is(60.0));
-
- Resource file2 = getResource(DUPLICATIONS + ":src/main/java/duplicated_lines_with_other_package2/DuplicatedLinesWithOtherPackage.java");
- assertThat(file2, not(nullValue()));
- assertThat(file2.getMeasureValue("duplicated_blocks"), is(1.0));
- assertThat(file2.getMeasureValue("duplicated_lines"), is(36.0));
- assertThat(file2.getMeasureValue("duplicated_files"), is(1.0));
- assertThat(file2.getMeasureValue("duplicated_lines_density"), is(60.0));
-
- Resource pkg2 = getResource(DUPLICATIONS + ":src/main/java/duplicated_lines_with_other_package2");
- assertThat(pkg2, not(nullValue()));
- assertThat(pkg2.getMeasureValue("duplicated_blocks"), is(1.0));
- assertThat(pkg2.getMeasureValue("duplicated_lines"), is(36.0));
- assertThat(pkg2.getMeasureValue("duplicated_files"), is(1.0));
- assertThat(pkg2.getMeasureValue("duplicated_lines_density"), is(60.0));
+ public void duplication_measures_on_project() {
+ verifyDuplicationMeasures(DUPLICATIONS, 9, 293, 8, 63.7);
}
@Test
- public void consolidation() {
- Resource project = getResource(DUPLICATIONS);
- assertThat(project, not(nullValue()));
- assertThat(project.getMeasureValue("duplicated_blocks"), is(14.0));
- assertThat(project.getMeasureValue("duplicated_lines"), is(343.0));
- assertThat(project.getMeasureValue("duplicated_files"), is(8.0));
- assertThat(project.getMeasureValue("duplicated_lines_density"), is(56.4));
+ public void project_without_enough_tokens_has_duplication() {
+ verifyDuplicationMeasures(WITHOUT_ENOUGH_TOKENS, 0, 0, 0, 0d);
}
/**
@@ -157,17 +109,62 @@ public class DuplicationsTest {
*/
@Test
public void use_duplication_exclusions() {
- Resource project = getResource(DUPLICATIONS_WITH_EXCLUSIONS);
- assertThat(project, not(nullValue()));
- assertThat(project.getMeasureValue("duplicated_blocks"), is(11.0));
- assertThat(project.getMeasureValue("duplicated_lines"), is(256.0));
- assertThat(project.getMeasureValue("duplicated_files"), is(5.0));
- assertThat(project.getMeasureValue("duplicated_lines_density"), is(42.1));
+ verifyDuplicationMeasures(DUPLICATIONS_WITH_EXCLUSIONS, 6, 198, 5, 43d);
}
- private Resource getResource(String key) {
- return orchestrator.getServer().getWsClient()
+ @Test
+ public void issues_on_duplicated_blocks_are_generated_on_each_file() throws Exception {
+ List<Issue> issues = orchestrator.getServer().wsClient().issueClient()
+ .find(IssueQuery.create()
+ .rules("common-xoo:DuplicatedBlocks"))
+ .list();
+ assertThat(issues).hasSize(13);
+ }
+
+ @Test
+ public void verify_sources_lines_ws_duplication_information() throws Exception {
+ verifyWsResultOnDuplicateFile(DUPLICATIONS + ":src/main/xoo/duplicated_lines_within_same_file/DuplicatedLinesInSameFile.xoo",
+ "api/sources/lines", "sources_lines_duplication-expected.json");
+ }
+
+ @Test
+ public void verify_duplications_show_ws() throws Exception {
+ verifyWsResultOnDuplicateFile(DUPLICATIONS + ":src/main/xoo/duplicated_lines_within_same_file/DuplicatedLinesInSameFile.xoo",
+ "api/duplications/show", "duplications_show-expected.json");
+ }
+
+ private static Resource getComponent(String key) {
+ Resource component = orchestrator.getServer().getWsClient()
.find(ResourceQuery.createForMetrics(key, "duplicated_lines", "duplicated_blocks", "duplicated_files", "duplicated_lines_density"));
+ assertThat(component).isNotNull();
+ return component;
+ }
+
+ private static void verifyDuplicationMeasures(String componentKey, int duplicatedBlocks, int duplicatedLines, int duplicatedFiles, double duplicatedLinesDensity) {
+ Resource file = getComponent(componentKey);
+ assertThat(file.getMeasureValue("duplicated_blocks").intValue()).isEqualTo(duplicatedBlocks);
+ assertThat(file.getMeasureValue("duplicated_lines").intValue()).isEqualTo(duplicatedLines);
+ assertThat(file.getMeasureValue("duplicated_files").intValue()).isEqualTo(duplicatedFiles);
+ assertThat(file.getMeasureValue("duplicated_lines_density")).isEqualTo(duplicatedLinesDensity);
+ }
+
+ private static void analyzeProject(String projectKey, String... additionalProperties) {
+ orchestrator.getServer().provisionProject(projectKey, projectKey);
+ orchestrator.getServer().associateProjectToQualityProfile(projectKey, "xoo", "xoo-duplication-profile");
+
+ runProjectAnalysis(orchestrator, "duplications/file-duplications",
+ ArrayUtils.addAll(
+ new String[] {
+ "sonar.projectKey", projectKey,
+ "sonar.projectName", projectKey
+ },
+ additionalProperties));
+ }
+
+ private static void verifyWsResultOnDuplicateFile(String fileKey, String ws, String expectedFilePath) throws Exception {
+ String duplication = orchestrator.getServer().adminWsClient().get(ws, "key", fileKey);
+ assertEquals(IOUtils.toString(CrossProjectDuplicationsTest.class.getResourceAsStream("/duplication/DuplicationsTest/" + expectedFilePath), "UTF-8"), duplication,
+ false);
}
}
diff --git a/it/it-tests/src/test/resources/duplication/DuplicationsTest/duplications_show-expected.json b/it/it-tests/src/test/resources/duplication/DuplicationsTest/duplications_show-expected.json
new file mode 100644
index 00000000000..83b69f2be1d
--- /dev/null
+++ b/it/it-tests/src/test/resources/duplication/DuplicationsTest/duplications_show-expected.json
@@ -0,0 +1,26 @@
+{
+ "duplications": [
+ {
+ "blocks": [
+ {
+ "from": 9,
+ "size": 29,
+ "_ref": "1"
+ },
+ {
+ "from": 40,
+ "size": 31,
+ "_ref": "1"
+ }
+ ]
+ }
+ ],
+ "files": {
+ "1": {
+ "key": "file-duplications:src/main/xoo/duplicated_lines_within_same_file/DuplicatedLinesInSameFile.xoo",
+ "name": "src/main/xoo/duplicated_lines_within_same_file/DuplicatedLinesInSameFile.xoo",
+ "project": "file-duplications",
+ "projectName": "file-duplications"
+ }
+ }
+}
diff --git a/it/it-tests/src/test/resources/duplication/DuplicationsTest/sources_lines_duplication-expected.json b/it/it-tests/src/test/resources/duplication/DuplicationsTest/sources_lines_duplication-expected.json
new file mode 100644
index 00000000000..f6ccc926f29
--- /dev/null
+++ b/it/it-tests/src/test/resources/duplication/DuplicationsTest/sources_lines_duplication-expected.json
@@ -0,0 +1,359 @@
+{
+ "sources": [
+ {
+ "line": 1,
+ "code": "package duplicated_lines_within_same_file;",
+ "duplicated": false
+ },
+ {
+ "line": 2,
+ "code": "",
+ "duplicated": false
+ },
+ {
+ "line": 3,
+ "code": "public class DuplicatedLinesInSameFile {",
+ "duplicated": false
+ },
+ {
+ "line": 4,
+ "code": "",
+ "duplicated": false
+ },
+ {
+ "line": 5,
+ "code": " public DuplicatedLinesInSameFile() {",
+ "duplicated": false
+ },
+ {
+ "line": 6,
+ "code": " }",
+ "duplicated": false
+ },
+ {
+ "line": 7,
+ "code": "",
+ "duplicated": false
+ },
+ {
+ "line": 8,
+ "code": " public void duplicatedMethodInSameFile1() {",
+ "duplicated": false
+ },
+ {
+ "line": 9,
+ "code": " String temp = \"\";",
+ "duplicated": true
+ },
+ {
+ "line": 10,
+ "code": " for (int i=0; i&lt;10; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 11,
+ "code": " temp += \"say something\"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 12,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 13,
+ "code": " for (int i=0; i&lt;20; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 14,
+ "code": " temp += \"say nothing\"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 15,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 16,
+ "code": " for (int i=0; i&lt;30; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 17,
+ "code": " temp += \"always say nothing\"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 18,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 19,
+ "code": " for (int i=0; i&lt;40; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 20,
+ "code": " temp += \"really nothing to say \"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 21,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 22,
+ "code": " for (int i=0; i&lt;50; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 23,
+ "code": " temp += \"really really nothing to say \"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 24,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 25,
+ "code": " for (int i=0; i&lt;60; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 26,
+ "code": " temp += \".. \"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 27,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 28,
+ "code": " for (int i=0; i&lt;70; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 29,
+ "code": " temp += \"you say something? \"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 30,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 31,
+ "code": " for (int i=0; i&lt;80; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 32,
+ "code": " temp += \"ah no...\"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 33,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 34,
+ "code": " for (int i=0; i&lt;90; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 35,
+ "code": " temp += \"bye\"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 36,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 37,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 38,
+ "code": "",
+ "duplicated": false
+ },
+ {
+ "line": 39,
+ "code": " public void duplicatedMethodInSameFile2() {",
+ "duplicated": false
+ },
+ {
+ "line": 40,
+ "code": " String temp = \"\";",
+ "duplicated": true
+ },
+ {
+ "line": 41,
+ "code": " for (int i=0; i&lt;10; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 42,
+ "code": " temp += \"say something\"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 43,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 44,
+ "code": " for (int i=0; i&lt;20; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 45,
+ "code": " temp += \"say nothing\"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 46,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 47,
+ "code": " for (int i=0; i&lt;30; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 48,
+ "code": " temp += \"always say nothing\"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 49,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 50,
+ "code": " for (int i=0; i&lt;40; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 51,
+ "code": " temp += \"really nothing to say \"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 52,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 53,
+ "code": " for (int i=0; i&lt;50; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 54,
+ "code": " temp += \"really really nothing to say \"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 55,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 56,
+ "code": " for (int i=0; i&lt;60; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 57,
+ "code": " temp += \".. \"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 58,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 59,
+ "code": " for (int i=0; i&lt;70; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 60,
+ "code": " temp += \"you say something? \"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 61,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 62,
+ "code": " for (int i=0; i&lt;80; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 63,
+ "code": " temp += \"ah no...\"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 64,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 65,
+ "code": " for (int i=0; i&lt;90; i++){",
+ "duplicated": true
+ },
+ {
+ "line": 66,
+ "code": " temp += \"bye\"+i;",
+ "duplicated": true
+ },
+ {
+ "line": 67,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 68,
+ "code": " }",
+ "duplicated": true
+ },
+ {
+ "line": 69,
+ "code": "",
+ "duplicated": true
+ },
+ {
+ "line": 70,
+ "code": "}",
+ "duplicated": true
+ },
+ {
+ "line": 71,
+ "code": "",
+ "duplicated": false
+ }
+ ]
+}