aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-batch/src
diff options
context:
space:
mode:
authorDuarte Meneses <duarte.meneses@sonarsource.com>2015-09-01 11:24:35 +0200
committerDuarte Meneses <duarte.meneses@sonarsource.com>2015-09-04 10:33:16 +0200
commit5f3df6283a0d506decec0049c6fde833eed69c63 (patch)
tree2e2f3f94787e71a67651e8fcb64405b8c5eb5f92 /sonar-batch/src
parentb87a4ac9478262ad261dbd6ec3378a7d4a46efd1 (diff)
downloadsonarqube-5f3df6283a0d506decec0049c6fde833eed69c63.tar.gz
sonarqube-5f3df6283a0d506decec0049c6fde833eed69c63.zip
Optimize project reactor builder
Diffstat (limited to 'sonar-batch/src')
-rw-r--r--sonar-batch/src/main/java/org/sonar/batch/scan/ProjectReactorBuilder.java65
-rw-r--r--sonar-batch/src/test/java/org/sonar/batch/scan/ProjectReactorBuilderTest.java6
-rw-r--r--sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-id/modules/module1/module1/sources/Fake.java (renamed from sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-names/modules/module1/module1/sources/Fake.java)0
-rw-r--r--sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-id/modules/module1/sources/Fake.java (renamed from sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-names/modules/module1/sources/Fake.java)0
-rw-r--r--sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-id/sonar-project.properties (renamed from sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-names/sonar-project.properties)0
5 files changed, 29 insertions, 42 deletions
diff --git a/sonar-batch/src/main/java/org/sonar/batch/scan/ProjectReactorBuilder.java b/sonar-batch/src/main/java/org/sonar/batch/scan/ProjectReactorBuilder.java
index abbb9602d1a..a20e8abd3e4 100644
--- a/sonar-batch/src/main/java/org/sonar/batch/scan/ProjectReactorBuilder.java
+++ b/sonar-batch/src/main/java/org/sonar/batch/scan/ProjectReactorBuilder.java
@@ -19,6 +19,8 @@
*/
package org.sonar.batch.scan;
+import org.apache.commons.lang.ArrayUtils;
+
import org.sonar.batch.analysis.AnalysisProperties;
import com.google.common.annotations.VisibleForTesting;
import com.google.common.collect.Lists;
@@ -30,14 +32,12 @@ import java.io.IOException;
import java.text.MessageFormat;
import java.util.ArrayList;
import java.util.Arrays;
-import java.util.Collection;
-import java.util.Collections;
import java.util.HashMap;
-import java.util.HashSet;
+import java.util.Iterator;
import java.util.List;
import java.util.Map;
+import java.util.Map.Entry;
import java.util.Properties;
-import java.util.Set;
import javax.annotation.CheckForNull;
import javax.annotation.Nullable;
@@ -118,59 +118,46 @@ public class ProjectReactorBuilder {
public ProjectReactor execute() {
Profiler profiler = Profiler.create(LOG).startInfo("Process project properties");
- Map<String, Map<String, String>> propertiesByModuleId = extractPropertiesByModule("", taskProps.properties());
+ Map<String, Map<String, String>> propertiesByModuleId = new HashMap<>();
+ extractPropertiesByModule(propertiesByModuleId, "", taskProps.properties());
ProjectDefinition rootProject = defineRootProject(propertiesByModuleId.get(""), null);
rootProjectWorkDir = rootProject.getWorkDir();
defineChildren(rootProject, propertiesByModuleId);
cleanAndCheckProjectDefinitions(rootProject);
// Since task properties are now empty we should add root module properties
- for (Map.Entry<String, String> entry : propertiesByModuleId.get("").entrySet()) {
- taskProps.properties().put((String) entry.getKey(), (String) entry.getValue());
- }
+ taskProps.properties().putAll(propertiesByModuleId.get(""));
profiler.stopDebug();
return new ProjectReactor(rootProject);
}
- private static Map<String, Map<String, String>> extractPropertiesByModule(String currentModuleId, Map<String, String> parentProperties) {
- Map<String, String> allProperties = new HashMap<>();
- allProperties.putAll(parentProperties);
+ private static void extractPropertiesByModule(Map<String, Map<String, String>> propertiesByModuleId, String currentModuleId, Map<String, String> parentProperties) {
+ if (propertiesByModuleId.containsKey(currentModuleId)) {
+ throw new IllegalStateException(String.format("Two modules have the same id: %s. Each module must have a unique id.", currentModuleId));
+ }
+
Map<String, String> currentModuleProperties = new HashMap<>();
- String prefix = !currentModuleId.isEmpty() ? currentModuleId + "." : "";
+ String prefix = !currentModuleId.isEmpty() ? (currentModuleId + ".") : "";
+ int prefixLength = prefix.length();
+
// By default all properties starting with module prefix belong to current module
- for (Map.Entry<String, String> entry : allProperties.entrySet()) {
- String key = entry.getKey();
- int prefixLength = prefix.length();
+ Iterator<Entry<String, String>> it = parentProperties.entrySet().iterator();
+ while (it.hasNext()) {
+ Map.Entry<String, String> e = it.next();
+ String key = e.getKey();
if (key.startsWith(prefix)) {
- currentModuleProperties.put(key.substring(prefixLength), entry.getValue());
- parentProperties.remove(key);
+ currentModuleProperties.put(key.substring(prefixLength), e.getValue());
+ it.remove();
}
}
- List<String> moduleIds = new ArrayList<>(Arrays.asList(getListFromProperty(currentModuleProperties, PROPERTY_MODULES)));
+ String[] moduleIds = getListFromProperty(currentModuleProperties, PROPERTY_MODULES);
// Sort module by reverse lexicographic order to avoid issue when one module id is a prefix of another one
- Collections.sort(moduleIds);
- Collections.reverse(moduleIds);
+ Arrays.sort(moduleIds);
+ ArrayUtils.reverse(moduleIds);
- Map<String, Map<String, String>> result = new HashMap<>();
- result.put(currentModuleId, currentModuleProperties);
+ propertiesByModuleId.put(currentModuleId, currentModuleProperties);
for (String moduleId : moduleIds) {
- Map<String, Map<String, String>> subModuleProps = extractPropertiesByModule(moduleId, currentModuleProperties);
- checkRepeatedModuleNames(result.keySet(), subModuleProps.keySet());
- result.putAll(subModuleProps);
- }
- return result;
- }
-
- private static void checkRepeatedModuleNames(Collection<String> currentModules, Collection<String> modulesToMerge) {
- Set<String> union = new HashSet<>();
- union.addAll(currentModules);
- union.retainAll(modulesToMerge);
- if (!union.isEmpty()) {
- if (union.size() > 1) {
- throw new IllegalStateException(String.format("Modules have the following repeated names: %s. Each module must have a unique name.", union));
- } else {
- throw new IllegalStateException(String.format("Two modules have the same name: %s. Each module must have a unique name.", union.iterator().next()));
- }
+ extractPropertiesByModule(propertiesByModuleId, moduleId, currentModuleProperties);
}
}
diff --git a/sonar-batch/src/test/java/org/sonar/batch/scan/ProjectReactorBuilderTest.java b/sonar-batch/src/test/java/org/sonar/batch/scan/ProjectReactorBuilderTest.java
index b4bdeb07877..82db9d87976 100644
--- a/sonar-batch/src/test/java/org/sonar/batch/scan/ProjectReactorBuilderTest.java
+++ b/sonar-batch/src/test/java/org/sonar/batch/scan/ProjectReactorBuilderTest.java
@@ -79,11 +79,11 @@ public class ProjectReactorBuilderTest {
}
@Test
- public void modulesRepeatedNames() {
+ public void modulesRepeatedIds() {
thrown.expect(IllegalStateException.class);
- thrown.expectMessage("Two modules have the same name: module1");
+ thrown.expectMessage("Two modules have the same id: module1");
- loadProjectDefinition("multi-module-repeated-names");
+ loadProjectDefinition("multi-module-repeated-id");
}
@Test
diff --git a/sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-names/modules/module1/module1/sources/Fake.java b/sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-id/modules/module1/module1/sources/Fake.java
index e67004defc5..e67004defc5 100644
--- a/sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-names/modules/module1/module1/sources/Fake.java
+++ b/sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-id/modules/module1/module1/sources/Fake.java
diff --git a/sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-names/modules/module1/sources/Fake.java b/sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-id/modules/module1/sources/Fake.java
index e67004defc5..e67004defc5 100644
--- a/sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-names/modules/module1/sources/Fake.java
+++ b/sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-id/modules/module1/sources/Fake.java
diff --git a/sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-names/sonar-project.properties b/sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-id/sonar-project.properties
index b1816be030b..b1816be030b 100644
--- a/sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-names/sonar-project.properties
+++ b/sonar-batch/src/test/resources/org/sonar/batch/scan/ProjectReactorBuilderTest/multi-module-repeated-id/sonar-project.properties