aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSimon Brandhof <simon.brandhof@gmail.com>2013-10-11 09:38:44 +0200
committerSimon Brandhof <simon.brandhof@gmail.com>2013-10-11 09:38:44 +0200
commit5d5c93e5c4181fc8cbdfaf6dba7b091fb8b0e16c (patch)
treed7a5d1d61c58b92735992813c67ad7488f54c6e6
parent7855fc19668960fd2e30d49ae5dd46feac943b90 (diff)
downloadsonarqube-5d5c93e5c4181fc8cbdfaf6dba7b091fb8b0e16c.tar.gz
sonarqube-5d5c93e5c4181fc8cbdfaf6dba7b091fb8b0e16c.zip
Fix MavenProjectConverter on MSWindows
-rw-r--r--plugins/sonar-maven-batch-plugin/src/main/java/org/sonar/plugins/maven/MavenProjectConverter.java38
-rw-r--r--plugins/sonar-maven-batch-plugin/src/test/java/org/sonar/plugins/maven/MavenProjectConverterTest.java2
2 files changed, 22 insertions, 18 deletions
diff --git a/plugins/sonar-maven-batch-plugin/src/main/java/org/sonar/plugins/maven/MavenProjectConverter.java b/plugins/sonar-maven-batch-plugin/src/main/java/org/sonar/plugins/maven/MavenProjectConverter.java
index 8dbd950b13b..9bc94112274 100644
--- a/plugins/sonar-maven-batch-plugin/src/main/java/org/sonar/plugins/maven/MavenProjectConverter.java
+++ b/plugins/sonar-maven-batch-plugin/src/main/java/org/sonar/plugins/maven/MavenProjectConverter.java
@@ -33,12 +33,11 @@ import org.sonar.api.CoreProperties;
import org.sonar.api.batch.bootstrap.ProjectDefinition;
import org.sonar.api.batch.maven.MavenUtils;
import org.sonar.api.task.TaskExtension;
-import org.sonar.api.utils.PathUtils;
-import org.sonar.api.utils.SonarException;
import org.sonar.batch.scan.filesystem.DefaultModuleFileSystem;
import org.sonar.java.api.JavaUtils;
import javax.annotation.Nullable;
+
import java.io.File;
import java.io.IOException;
import java.util.Arrays;
@@ -55,8 +54,13 @@ public class MavenProjectConverter implements TaskExtension {
Map<String, MavenProject> paths = Maps.newHashMap();
Map<MavenProject, ProjectDefinition> defs = Maps.newHashMap();
- configureModules(poms, paths, defs);
- rebuildModuleHierarchy(paths, defs);
+ try {
+ configureModules(poms, paths, defs);
+
+ rebuildModuleHierarchy(paths, defs);
+ } catch (IOException e) {
+ throw new IllegalStateException("Cannot configure project", e);
+ }
ProjectDefinition rootProject = defs.get(root);
if (rootProject == null) {
@@ -65,7 +69,7 @@ public class MavenProjectConverter implements TaskExtension {
return rootProject;
}
- private void rebuildModuleHierarchy(Map<String, MavenProject> paths, Map<MavenProject, ProjectDefinition> defs) {
+ private void rebuildModuleHierarchy(Map<String, MavenProject> paths, Map<MavenProject, ProjectDefinition> defs) throws IOException {
for (Map.Entry<String, MavenProject> entry : paths.entrySet()) {
MavenProject pom = entry.getValue();
for (Object m : pom.getModules()) {
@@ -86,26 +90,26 @@ public class MavenProjectConverter implements TaskExtension {
}
}
- private void configureModules(List<MavenProject> poms, Map<String, MavenProject> paths, Map<MavenProject, ProjectDefinition> defs) {
+ private void configureModules(List<MavenProject> poms, Map<String, MavenProject> paths, Map<MavenProject, ProjectDefinition> defs) throws IOException {
for (MavenProject pom : poms) {
- paths.put(PathUtils.canonicalPath(pom.getFile()), pom);
+ paths.put(pom.getFile().getCanonicalPath(), pom);
ProjectDefinition def = ProjectDefinition.create();
merge(pom, def);
defs.put(pom, def);
}
}
- private static MavenProject findMavenProject(final File modulePath, Map<String, MavenProject> paths) {
+ private static MavenProject findMavenProject(final File modulePath, Map<String, MavenProject> paths) throws IOException {
if (modulePath.exists() && modulePath.isDirectory()) {
for (Map.Entry<String, MavenProject> entry : paths.entrySet()) {
String pomFileParentDir = new File(entry.getKey()).getParent();
- if (pomFileParentDir.equals(PathUtils.canonicalPath(modulePath))) {
+ if (pomFileParentDir.equals(modulePath.getCanonicalPath())) {
return entry.getValue();
}
}
return null;
}
- return paths.get(PathUtils.canonicalPath(modulePath));
+ return paths.get(modulePath.getCanonicalPath());
}
@VisibleForTesting
@@ -114,12 +118,12 @@ public class MavenProjectConverter implements TaskExtension {
// IMPORTANT NOTE : reference on properties from POM model must not be saved,
// instead they should be copied explicitly - see SONAR-2896
definition
- .setProperties(pom.getModel().getProperties())
- .setKey(key)
- .setVersion(pom.getVersion())
- .setName(pom.getName())
- .setDescription(pom.getDescription())
- .addContainerExtension(pom);
+ .setProperties(pom.getModel().getProperties())
+ .setKey(key)
+ .setVersion(pom.getVersion())
+ .setName(pom.getName())
+ .setDescription(pom.getDescription())
+ .addContainerExtension(pom);
guessJavaVersion(pom, definition);
guessEncoding(pom, definition);
convertMavenLinksToProperties(definition, pom);
@@ -234,7 +238,7 @@ public class MavenProjectConverter implements TaskExtension {
try {
file = new File(basedir, path).getCanonicalFile();
} catch (IOException e) {
- throw new SonarException("Unable to resolve path '" + path + "'", e);
+ throw new IllegalStateException("Unable to resolve path '" + path + "'", e);
}
}
return file;
diff --git a/plugins/sonar-maven-batch-plugin/src/test/java/org/sonar/plugins/maven/MavenProjectConverterTest.java b/plugins/sonar-maven-batch-plugin/src/test/java/org/sonar/plugins/maven/MavenProjectConverterTest.java
index 4c25ec45c40..6b060ab75e7 100644
--- a/plugins/sonar-maven-batch-plugin/src/test/java/org/sonar/plugins/maven/MavenProjectConverterTest.java
+++ b/plugins/sonar-maven-batch-plugin/src/test/java/org/sonar/plugins/maven/MavenProjectConverterTest.java
@@ -51,7 +51,7 @@ public class MavenProjectConverterTest {
@Rule
public TemporaryFolder temp = new TemporaryFolder();
- private MavenProjectConverter mavenProjectConverter = new MavenProjectConverter();
+ MavenProjectConverter mavenProjectConverter = new MavenProjectConverter();
/**
* See SONAR-2681