aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDuarte Meneses <duarte.meneses@sonarsource.com>2016-03-17 12:51:00 +0100
committerDuarte Meneses <duarte.meneses@sonarsource.com>2016-03-17 13:35:30 +0100
commitfaef791d6369f0301d8fcbee5c255a4a593059f1 (patch)
treefa2421df0cd608a3125b3738ac99b042d24e53ec
parenta1ae6a8c514a46cd55823f28fdd9705c9ebd544e (diff)
downloadsonar-scanner-cli-faef791d6369f0301d8fcbee5c255a4a593059f1.tar.gz
sonar-scanner-cli-faef791d6369f0301d8fcbee5c255a4a593059f1.zip
SQSCANNER-14 Always configure project base directory
-rw-r--r--src/main/java/org/sonarsource/scanner/cli/Conf.java201
-rw-r--r--src/test/java/org/sonarsource/scanner/cli/ConfTest.java144
-rw-r--r--src/test/resources/org/sonarsource/scanner/cli/ConfTest/shouldLoadModuleConfigurationOverrideBasedir/project/module_2/sonar-project.properties1
-rw-r--r--src/test/resources/org/sonarsource/scanner/cli/ConfTest/shouldLoadModuleConfigurationWithoutRootConf/project/module1/sonar-project.properties1
-rw-r--r--src/test/resources/org/sonarsource/scanner/cli/ConfTest/shouldLoadModuleConfigurationWithoutRootConf/project/module2/sonar-project.properties1
5 files changed, 232 insertions, 116 deletions
diff --git a/src/main/java/org/sonarsource/scanner/cli/Conf.java b/src/main/java/org/sonarsource/scanner/cli/Conf.java
index 7746ee8..74f0f62 100644
--- a/src/main/java/org/sonarsource/scanner/cli/Conf.java
+++ b/src/main/java/org/sonarsource/scanner/cli/Conf.java
@@ -19,15 +19,16 @@
*/
package org.sonarsource.scanner.cli;
-import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
+import java.nio.file.Files;
+import java.nio.file.Path;
+import java.nio.file.Paths;
import java.text.MessageFormat;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
-import java.util.Map.Entry;
import java.util.Properties;
class Conf {
@@ -54,14 +55,16 @@ class Conf {
result.putAll(loadProjectProperties());
result.putAll(System.getProperties());
result.putAll(cli.properties());
+ // root project base directory must be present and be absolute
+ result.setProperty(PROPERTY_PROJECT_BASEDIR, getRootProjectBaseDir(result).toString());
result.remove(PROJECT_HOME);
return result;
}
private Properties loadGlobalProperties() throws IOException {
- File settingsFile = locatePropertiesFile(cli.properties(), RUNNER_HOME, "conf/sonar-runner.properties", RUNNER_SETTINGS);
- if (settingsFile != null && settingsFile.isFile() && settingsFile.exists()) {
- logger.info("Scanner configuration file: " + settingsFile.getAbsolutePath());
+ Path settingsFile = locatePropertiesFile(cli.properties(), RUNNER_HOME, "conf/sonar-runner.properties", RUNNER_SETTINGS);
+ if (settingsFile != null && Files.isRegularFile(settingsFile)) {
+ logger.info("Scanner configuration file: " + settingsFile);
return toProperties(settingsFile);
}
logger.info("Scanner configuration file: NONE");
@@ -69,38 +72,57 @@ class Conf {
}
private Properties loadProjectProperties() throws IOException {
- Properties cliProps = cli.properties();
- File rootSettingsFile = locatePropertiesFile(cliProps, cliProps.containsKey(PROPERTY_PROJECT_BASEDIR) ? PROPERTY_PROJECT_BASEDIR : PROJECT_HOME,
- SONAR_PROJECT_PROPERTIES_FILENAME,
- PROJECT_SETTINGS);
- if (rootSettingsFile != null && rootSettingsFile.isFile() && rootSettingsFile.exists()) {
- logger.info("Project configuration file: " + rootSettingsFile.getAbsolutePath());
- Properties projectProps = new Properties();
- Properties rootProps = toProperties(rootSettingsFile);
- projectProps.putAll(rootProps);
- initRootProjectBaseDir(cliProps, rootProps);
- loadModulesProperties(rootProps, projectProps, "");
- return projectProps;
+ Properties rootProps = new Properties();
+ Properties knownProps = new Properties();
+
+ knownProps.putAll(System.getProperties());
+ knownProps.putAll(cli.properties());
+
+ Path defaultRootSettingsFile = getRootProjectBaseDir(knownProps).resolve(SONAR_PROJECT_PROPERTIES_FILENAME);
+ Path rootSettingsFile = locatePropertiesFile(defaultRootSettingsFile, knownProps, PROJECT_SETTINGS);
+ if (rootSettingsFile != null && Files.isRegularFile(rootSettingsFile)) {
+ logger.info("Project root configuration file: " + rootSettingsFile);
+ rootProps.putAll(toProperties(rootSettingsFile));
+ } else {
+ logger.info("Project root configuration file: NONE");
}
- logger.info("Project configuration file: NONE");
- return new Properties();
+
+ Properties projectProps = new Properties();
+
+ // include already root base directory and eventually props loaded from root config file
+ projectProps.putAll(rootProps);
+
+ rootProps.putAll(knownProps);
+ rootProps.setProperty(PROPERTY_PROJECT_BASEDIR, getRootProjectBaseDir(rootProps).toString());
+
+ // projectProps will be overridden by any properties found in child project settings
+ loadModulesProperties(rootProps, projectProps, "");
+ return projectProps;
}
- private static void initRootProjectBaseDir(Properties cliProps, Properties rootProps) {
- if (!cliProps.containsKey(PROPERTY_PROJECT_BASEDIR)) {
- String baseDir = cliProps.getProperty(PROJECT_HOME);
- rootProps.put(PROPERTY_PROJECT_BASEDIR, baseDir);
+ private static Path getRootProjectBaseDir(Properties cliProps) {
+ Path absoluteProjectHome;
+ if (cliProps.containsKey(PROJECT_HOME)) {
+ absoluteProjectHome = Paths.get(cliProps.getProperty(PROJECT_HOME)).toAbsolutePath();
} else {
- rootProps.put(PROPERTY_PROJECT_BASEDIR, cliProps.getProperty(PROPERTY_PROJECT_BASEDIR));
+ // this should always be avoided, as it will resolve symbolic links
+ absoluteProjectHome = Paths.get("").toAbsolutePath();
}
+
+ if (!cliProps.containsKey(PROPERTY_PROJECT_BASEDIR)) {
+ return absoluteProjectHome;
+ }
+
+ return getAbsolutePath(cliProps.getProperty(PROPERTY_PROJECT_BASEDIR), absoluteProjectHome);
}
private void loadModulesProperties(Properties parentProps, Properties projectProps, String prefix) {
- File parentBaseDir = new File(parentProps.getProperty(PROPERTY_PROJECT_BASEDIR));
+ Path parentBaseDir = Paths.get(parentProps.getProperty(PROPERTY_PROJECT_BASEDIR));
if (parentProps.containsKey(PROPERTY_MODULES)) {
for (String module : getListFromProperty(parentProps, PROPERTY_MODULES)) {
Properties moduleProps = extractModuleProperties(module, parentProps);
- moduleProps = loadChildConfigFile(parentBaseDir, moduleProps, module);
+ //higher priority to child configuration files
+ loadModuleConfigFile(parentBaseDir, moduleProps, module);
// the child project may have children as well
loadModulesProperties(moduleProps, projectProps, prefix + module + ".");
@@ -117,36 +139,34 @@ class Conf {
}
}
- private Properties loadChildConfigFile(File parentBaseDir, Properties moduleProps, String moduleId) {
- final File baseDir;
+ private void loadModuleConfigFile(Path parentAbsBaseDir, Properties moduleProps, String moduleId) {
+ final Path absoluteBaseDir;
+
if (moduleProps.containsKey(PROPERTY_PROJECT_BASEDIR)) {
- baseDir = getFileFromPath(moduleProps.getProperty(PROPERTY_PROJECT_BASEDIR), parentBaseDir);
- setProjectBaseDir(baseDir, moduleProps, moduleId);
+ absoluteBaseDir = getAbsolutePath(moduleProps.getProperty(PROPERTY_PROJECT_BASEDIR), parentAbsBaseDir);
+ setModuleBaseDir(absoluteBaseDir, moduleProps, moduleId);
try {
- if (!parentBaseDir.getCanonicalFile().equals(baseDir.getCanonicalFile())) {
- tryToFindAndLoadPropsFile(baseDir, moduleProps, moduleId);
+ if (!Files.isSameFile(parentAbsBaseDir, absoluteBaseDir)) {
+ tryToFindAndLoadPropsFile(absoluteBaseDir, moduleProps, moduleId);
}
} catch (IOException e) {
throw new IllegalStateException("Error when resolving baseDir", e);
}
} else if (moduleProps.containsKey(PROPERTY_PROJECT_CONFIG_FILE)) {
- baseDir = loadPropsFile(parentBaseDir, moduleProps, moduleId);
- setProjectBaseDir(baseDir, moduleProps, moduleId);
+ loadModulePropsFile(parentAbsBaseDir, moduleProps, moduleId);
moduleProps.remove(PROPERTY_PROJECT_CONFIG_FILE);
} else {
- baseDir = new File(parentBaseDir, moduleId);
- setProjectBaseDir(baseDir, moduleProps, moduleId);
- tryToFindAndLoadPropsFile(baseDir, moduleProps, moduleId);
+ absoluteBaseDir = parentAbsBaseDir.resolve(moduleId);
+ setModuleBaseDir(absoluteBaseDir, moduleProps, moduleId);
+ tryToFindAndLoadPropsFile(absoluteBaseDir, moduleProps, moduleId);
}
-
- return moduleProps;
}
- private static void setProjectBaseDir(File baseDir, Properties childProps, String moduleId) {
- if (!baseDir.isDirectory()) {
- throw new IllegalStateException(MessageFormat.format("The base directory of the module ''{0}'' does not exist: {1}", moduleId, baseDir.getAbsolutePath()));
+ private static void setModuleBaseDir(Path absoluteBaseDir, Properties childProps, String moduleId) {
+ if (!Files.isDirectory(absoluteBaseDir)) {
+ throw new IllegalStateException(MessageFormat.format("The base directory of the module ''{0}'' does not exist: {1}", moduleId, absoluteBaseDir));
}
- childProps.put(PROPERTY_PROJECT_BASEDIR, baseDir.getAbsolutePath());
+ childProps.put(PROPERTY_PROJECT_BASEDIR, absoluteBaseDir.toString());
}
protected static Properties extractModuleProperties(String module, Properties properties) {
@@ -162,94 +182,83 @@ class Conf {
return moduleProps;
}
- private static File locatePropertiesFile(Properties props, String homeKey, String relativePathFromHome, String settingsKey) {
- File settingsFile = null;
+ private static Path locatePropertiesFile(Properties props, String homeKey, String relativePathFromHome, String settingsKey) {
+ Path settingsFile = null;
String runnerHome = props.getProperty(homeKey, "");
if (!"".equals(runnerHome)) {
- settingsFile = new File(runnerHome, relativePathFromHome);
+ settingsFile = Paths.get(runnerHome, relativePathFromHome);
}
- if (settingsFile == null || !settingsFile.exists()) {
+ return locatePropertiesFile(settingsFile, props, settingsKey);
+ }
+
+ private static Path locatePropertiesFile(Path defaultPath, Properties props, String settingsKey) {
+ Path settingsFile = defaultPath;
+ if (settingsFile == null || !Files.exists(settingsFile)) {
String settingsPath = props.getProperty(settingsKey, "");
if (!"".equals(settingsPath)) {
- settingsFile = new File(settingsPath);
+ settingsFile = Paths.get(settingsPath);
}
}
- return settingsFile;
+
+ if (settingsFile != null) {
+ return settingsFile.toAbsolutePath();
+ }
+ return null;
}
- private static Properties toProperties(File file) {
- InputStream in = null;
- try {
- Properties properties = new Properties();
- in = new FileInputStream(file);
+ private static Properties toProperties(Path file) {
+ Properties properties = new Properties();
+ try (InputStream in = new FileInputStream(file.toFile())) {
properties.load(in);
// Trim properties
for (String propKey : properties.stringPropertyNames()) {
properties.setProperty(propKey, properties.getProperty(propKey).trim());
}
return properties;
-
} catch (Exception e) {
- throw new IllegalStateException("Fail to load file: " + file.getAbsolutePath(), e);
-
- } finally {
- if (in != null) {
- try {
- in.close();
- } catch (IOException e) {
- // Ignore errors
- }
- }
+ throw new IllegalStateException("Fail to load file: " + file, e);
}
}
- /**
- * @return baseDir
- */
- protected File loadPropsFile(File parentBaseDir, Properties moduleProps, String moduleId) {
- File propertyFile = getFileFromPath(moduleProps.getProperty(PROPERTY_PROJECT_CONFIG_FILE), parentBaseDir);
- if (propertyFile.isFile()) {
- Properties propsFromFile = toProperties(propertyFile);
- for (Entry<Object, Object> entry : propsFromFile.entrySet()) {
- moduleProps.put(entry.getKey(), entry.getValue());
- }
- File baseDir = null;
+ protected void loadModulePropsFile(Path parentAbsoluteBaseDir, Properties moduleProps, String moduleId) {
+ Path propertyFile = getAbsolutePath(moduleProps.getProperty(PROPERTY_PROJECT_CONFIG_FILE), parentAbsoluteBaseDir);
+ if (Files.isRegularFile(propertyFile)) {
+ moduleProps.putAll(toProperties(propertyFile));
+ Path absoluteBaseDir;
if (moduleProps.containsKey(PROPERTY_PROJECT_BASEDIR)) {
- baseDir = getFileFromPath(moduleProps.getProperty(PROPERTY_PROJECT_BASEDIR), propertyFile.getParentFile());
+ absoluteBaseDir = getAbsolutePath(moduleProps.getProperty(PROPERTY_PROJECT_BASEDIR), propertyFile.getParent());
} else {
- baseDir = propertyFile.getParentFile();
+ absoluteBaseDir = propertyFile.getParent();
}
- setProjectBaseDir(baseDir, moduleProps, moduleId);
- return baseDir;
+ setModuleBaseDir(absoluteBaseDir, moduleProps, moduleId);
} else {
- throw new IllegalStateException("The properties file of the module '" + moduleId + "' does not exist: " + propertyFile.getAbsolutePath());
+ throw new IllegalStateException("The properties file of the module '" + moduleId + "' does not exist: " + propertyFile);
}
}
- private static void tryToFindAndLoadPropsFile(File baseDir, Properties moduleProps, String moduleId) {
- File propertyFile = new File(baseDir, SONAR_PROJECT_PROPERTIES_FILENAME);
- if (propertyFile.isFile()) {
- Properties propsFromFile = toProperties(propertyFile);
- for (Entry<Object, Object> entry : propsFromFile.entrySet()) {
- moduleProps.put(entry.getKey(), entry.getValue());
- }
- if (moduleProps.containsKey(PROPERTY_PROJECT_BASEDIR)) {
- File overwrittenBaseDir = getFileFromPath(moduleProps.getProperty(PROPERTY_PROJECT_BASEDIR), propertyFile.getParentFile());
- setProjectBaseDir(overwrittenBaseDir, moduleProps, moduleId);
- }
+ private static void tryToFindAndLoadPropsFile(Path absoluteBaseDir, Properties moduleProps, String moduleId) {
+ Path propertyFile = absoluteBaseDir.resolve(SONAR_PROJECT_PROPERTIES_FILENAME);
+ if (!Files.isRegularFile(propertyFile)) {
+ return;
+ }
+
+ moduleProps.putAll(toProperties(propertyFile));
+ if (moduleProps.containsKey(PROPERTY_PROJECT_BASEDIR)) {
+ Path overwrittenBaseDir = getAbsolutePath(moduleProps.getProperty(PROPERTY_PROJECT_BASEDIR), propertyFile.getParent());
+ setModuleBaseDir(overwrittenBaseDir, moduleProps, moduleId);
}
}
/**
* Returns the file denoted by the given path, may this path be relative to "baseDir" or absolute.
*/
- protected static File getFileFromPath(String path, File baseDir) {
- File propertyFile = new File(path.trim());
+ protected static Path getAbsolutePath(String path, Path baseDir) {
+ Path propertyFile = Paths.get(path.trim());
if (!propertyFile.isAbsolute()) {
- propertyFile = new File(baseDir, propertyFile.getPath());
+ propertyFile = baseDir.resolve(propertyFile);
}
- return propertyFile;
+ return propertyFile.normalize();
}
/**
diff --git a/src/test/java/org/sonarsource/scanner/cli/ConfTest.java b/src/test/java/org/sonarsource/scanner/cli/ConfTest.java
index d438464..c792504 100644
--- a/src/test/java/org/sonarsource/scanner/cli/ConfTest.java
+++ b/src/test/java/org/sonarsource/scanner/cli/ConfTest.java
@@ -19,7 +19,11 @@
*/
package org.sonarsource.scanner.cli;
-import java.io.File;
+import java.io.IOException;
+import java.net.URISyntaxException;
+import java.nio.file.Files;
+import java.nio.file.Path;
+import java.nio.file.Paths;
import java.util.Properties;
import org.junit.Before;
import org.junit.Rule;
@@ -47,54 +51,72 @@ public class ConfTest {
@Test
public void should_load_global_settings_by_home() throws Exception {
- File home = new File(getClass().getResource("ConfTest/shouldLoadRunnerSettingsByHome/").toURI());
- args.setProperty("runner.home", home.getCanonicalPath());
+ Path home = Paths.get(getClass().getResource("ConfTest/shouldLoadRunnerSettingsByHome/").toURI());
+ args.setProperty("runner.home", home.toAbsolutePath().toString());
- assertThat(conf.properties().get("sonar.prop")).isEqualTo("value");
+ Properties properties = conf.properties();
+ assertThat(properties.get("sonar.prop")).isEqualTo("value");
}
@Test
public void should_not_fail_if_no_home() throws Exception {
assertThat(conf.properties()).isNotEmpty();
+ // worst case, use current path
+ assertThat(conf.properties().getProperty("sonar.projectBaseDir")).isEqualTo(Paths.get("").toAbsolutePath().toString());
+ }
+
+ @Test
+ public void base_dir_can_be_relative() throws URISyntaxException, IOException {
+ Path projectHome = Paths.get(getClass().getResource("ConfTest/shouldLoadModuleConfiguration/project").toURI());
+ args.setProperty("project.home", projectHome.getParent().toAbsolutePath().toString());
+ args.setProperty("sonar.projectBaseDir", "project");
+
+ Properties properties = conf.properties();
+
+ assertThat(properties.getProperty("module1.sonar.projectName")).isEqualTo("Module 1");
+ assertThat(properties.getProperty("module2.sonar.projectName")).isEqualTo("Module 2");
+ assertThat(properties.getProperty("sonar.projectBaseDir")).isEqualTo(projectHome.toString());
}
@Test
public void should_load_conf_by_direct_path() throws Exception {
- File settings = new File(getClass().getResource("ConfTest/shouldLoadRunnerSettingsByDirectPath/other-conf.properties").toURI());
- args.setProperty("runner.settings", settings.getCanonicalPath());
+ Path settings = Paths.get(getClass().getResource("ConfTest/shouldLoadRunnerSettingsByDirectPath/other-conf.properties").toURI());
+ args.setProperty("runner.settings", settings.toAbsolutePath().toString());
assertThat(conf.properties().get("sonar.prop")).isEqualTo("otherValue");
}
@Test
public void shouldLoadCompleteConfiguration() throws Exception {
- File runnerHome = new File(getClass().getResource("ConfTest/shouldLoadCompleteConfiguration/runner").toURI());
- File projectHome = new File(getClass().getResource("ConfTest/shouldLoadCompleteConfiguration/project").toURI());
- args.setProperty("runner.home", runnerHome.getCanonicalPath());
- args.setProperty("project.home", projectHome.getCanonicalPath());
+ Path runnerHome = Paths.get(getClass().getResource("ConfTest/shouldLoadCompleteConfiguration/runner").toURI());
+ Path projectHome = Paths.get(getClass().getResource("ConfTest/shouldLoadCompleteConfiguration/project").toURI());
+ args.setProperty("runner.home", runnerHome.toAbsolutePath().toString());
+ args.setProperty("project.home", projectHome.toAbsolutePath().toString());
Properties properties = conf.properties();
assertThat(properties.getProperty("project.prop")).isEqualTo("foo");
assertThat(properties.getProperty("overridden.prop")).isEqualTo("project scope");
assertThat(properties.getProperty("global.prop")).isEqualTo("jdbc:mysql:localhost/sonar");
+ assertThat(properties.getProperty("sonar.projectBaseDir")).isEqualTo(projectHome.toString());
}
@Test
public void shouldLoadModuleConfiguration() throws Exception {
- File projectHome = new File(getClass().getResource("ConfTest/shouldLoadModuleConfiguration/project").toURI());
- args.setProperty("project.home", projectHome.getCanonicalPath());
+ Path projectHome = Paths.get(getClass().getResource("ConfTest/shouldLoadModuleConfiguration/project").toURI());
+ args.setProperty("project.home", projectHome.toAbsolutePath().toString());
Properties properties = conf.properties();
assertThat(properties.getProperty("module1.sonar.projectName")).isEqualTo("Module 1");
assertThat(properties.getProperty("module2.sonar.projectName")).isEqualTo("Module 2");
+ assertThat(properties.getProperty("sonar.projectBaseDir")).isEqualTo(projectHome.toString());
}
@Test
public void shouldSupportDeepModuleConfigurationInRoot() throws Exception {
- File projectHome = new File(getClass().getResource("ConfTest/shouldSupportDeepModuleConfigurationInRoot/project").toURI());
- args.setProperty("project.home", projectHome.getCanonicalPath());
+ Path projectHome = Paths.get(getClass().getResource("ConfTest/shouldSupportDeepModuleConfigurationInRoot/project").toURI());
+ args.setProperty("project.home", projectHome.toAbsolutePath().toString());
Properties properties = conf.properties();
@@ -106,37 +128,97 @@ public class ConfTest {
// SONARUNNER-125
assertThat(properties.getProperty("11.111.sonar.projectName")).isNull();
+ assertThat(properties.getProperty("sonar.projectBaseDir")).isEqualTo(projectHome.toString());
}
@Test
public void shouldLoadModuleConfigurationOverrideBasedir() throws Exception {
- File projectHome = new File(getClass().getResource("ConfTest/shouldLoadModuleConfigurationOverrideBasedir/project").toURI());
- args.setProperty("project.home", projectHome.getCanonicalPath());
+ Path projectHome = Paths.get(getClass().getResource("ConfTest/shouldLoadModuleConfigurationOverrideBasedir/project").toURI());
+ args.setProperty("project.home", projectHome.toAbsolutePath().toString());
+
+ Properties properties = conf.properties();
+
+ assertThat(properties.getProperty("module1.sonar.projectName")).isEqualTo("Module 1");
+ assertThat(properties.getProperty("module2.sonar.projectName")).isEqualTo("Module 2");
+ assertThat(properties.getProperty("module3.sonar.projectName")).isEqualTo("Module 3");
+ assertThat(properties.getProperty("sonar.projectBaseDir")).isEqualTo(projectHome.toString());
+ }
+
+ @Test
+ public void shouldCliOverrideSettingFiles() throws Exception {
+ Path projectHome = Paths.get(getClass().getResource("ConfTest/shouldLoadModuleConfigurationOverrideBasedir/project").toURI());
+ args.setProperty("project.home", projectHome.toAbsolutePath().toString());
+ args.setProperty("module1.sonar.projectName", "mod1");
+ args.setProperty("module2.sonar.projectName", "mod2");
+ args.setProperty("module3.sonar.projectName", "mod3");
+
+ Properties properties = conf.properties();
+
+ assertThat(properties.getProperty("module1.sonar.projectName")).isEqualTo("mod1");
+ assertThat(properties.getProperty("module2.sonar.projectName")).isEqualTo("mod2");
+ assertThat(properties.getProperty("module3.sonar.projectName")).isEqualTo("mod3");
+ assertThat(properties.getProperty("sonar.projectBaseDir")).isEqualTo(projectHome.toString());
+ }
+
+ @Test
+ public void shouldUseCliToDiscoverModules() throws Exception {
+ Path projectHome = Paths.get(getClass().getResource("ConfTest/shouldLoadModuleConfigurationOverrideBasedir/project").toURI());
+ args.setProperty("project.home", projectHome.toAbsolutePath().toString());
+ args.setProperty("sonar.modules", "module1");
+ args.setProperty("module1.sonar.projectBaseDir", "module_3");
+
+ Properties properties = conf.properties();
+
+ assertThat(properties.getProperty("module1.sonar.projectName")).isEqualTo("Module 3");
+ assertThat(properties.getProperty("module2.sonar.projectName")).isNull();
+ assertThat(properties.getProperty("module3.sonar.projectName")).isNull();
+ assertThat(properties.getProperty("sonar.projectBaseDir")).isEqualTo(projectHome.toString());
+ }
+
+ @Test
+ public void shouldNotUseCurrentDir() throws Exception {
+ Path projectHome = Paths.get(getClass().getResource("ConfTest/shouldLoadModuleConfigurationOverrideBasedir/project").toURI());
+ args.setProperty("project.home", projectHome.toAbsolutePath().toString());
Properties properties = conf.properties();
assertThat(properties.getProperty("module1.sonar.projectName")).isEqualTo("Module 1");
assertThat(properties.getProperty("module2.sonar.projectName")).isEqualTo("Module 2");
assertThat(properties.getProperty("module3.sonar.projectName")).isEqualTo("Module 3");
+ assertThat(properties.getProperty("sonar.projectBaseDir")).isEqualTo(projectHome.toString());
+ }
+
+ @Test
+ public void shouldLoadModuleConfigurationWithoutRootConf() throws Exception {
+ Path projectHome = Paths.get(getClass().getResource("ConfTest/shouldLoadModuleConfigurationWithoutRootConf/project").toURI());
+ args.setProperty("project.home", projectHome.toAbsolutePath().toString());
+
+ args.put("sonar.modules", "module1,module2");
+ Properties properties = conf.properties();
+
+ assertThat(properties.getProperty("module1.sonar.projectName")).isEqualTo("Module 1");
+ assertThat(properties.getProperty("module2.sonar.projectName")).isEqualTo("Module 2");
+ assertThat(properties.getProperty("sonar.projectBaseDir")).isEqualTo(projectHome.toString());
}
@Test
public void shouldSupportSettingBaseDirFromCli() throws Exception {
- File projectHome = new File(getClass().getResource("ConfTest/shouldLoadModuleConfiguration/project").toURI());
+ Path projectHome = Paths.get(getClass().getResource("ConfTest/shouldLoadModuleConfiguration/project").toURI());
args.setProperty("project.home", temp.newFolder().getCanonicalPath());
- args.setProperty("sonar.projectBaseDir", projectHome.getCanonicalPath());
+ args.setProperty("sonar.projectBaseDir", projectHome.toAbsolutePath().toString());
Properties properties = conf.properties();
assertThat(properties.getProperty("module1.sonar.projectName")).isEqualTo("Module 1");
assertThat(properties.getProperty("module2.sonar.projectName")).isEqualTo("Module 2");
+ assertThat(properties.getProperty("sonar.projectBaseDir")).isEqualTo(projectHome.toString());
}
@Test
public void ignoreEmptyModule() throws Exception {
- File projectHome = new File(getClass().getResource("ConfTest/emptyModules/project").toURI());
+ Path projectHome = Paths.get(getClass().getResource("ConfTest/emptyModules/project").toURI());
args.setProperty("project.home", temp.newFolder().getCanonicalPath());
- args.setProperty("sonar.projectBaseDir", projectHome.getCanonicalPath());
+ args.setProperty("sonar.projectBaseDir", projectHome.toAbsolutePath().toString());
conf.properties();
}
@@ -149,4 +231,26 @@ public class ConfTest {
assertThat(Conf.getListFromProperty(props, "prop")).containsOnly("foo", "bar", "toto", "tutu");
}
+ @Test
+ public void shouldNotResolveSymlinks() throws IOException, URISyntaxException {
+ Path root = temp.getRoot().toPath();
+ Path realProjectHome = Paths.get(getClass().getResource("ConfTest/shouldLoadModuleConfiguration/project").toURI());
+ Path linkProjectHome = root.resolve("link");
+ try {
+ Files.createSymbolicLink(linkProjectHome, realProjectHome);
+
+ args.setProperty("project.home", linkProjectHome.toAbsolutePath().toString());
+
+ Properties properties = conf.properties();
+ assertThat(properties.getProperty("module1.sonar.projectName")).isEqualTo("Module 1");
+ assertThat(properties.getProperty("module2.sonar.projectName")).isEqualTo("Module 2");
+ assertThat(properties.getProperty("sonar.projectBaseDir")).isEqualTo(linkProjectHome.toString());
+ assertThat(properties.getProperty("module1.sonar.projectBaseDir")).isEqualTo(linkProjectHome.resolve("module1").toString());
+ assertThat(properties.getProperty("module2.sonar.projectBaseDir")).isEqualTo(linkProjectHome.resolve("module2").toString());
+ } finally {
+ if (linkProjectHome != null) {
+ Files.delete(linkProjectHome);
+ }
+ }
+ }
}
diff --git a/src/test/resources/org/sonarsource/scanner/cli/ConfTest/shouldLoadModuleConfigurationOverrideBasedir/project/module_2/sonar-project.properties b/src/test/resources/org/sonarsource/scanner/cli/ConfTest/shouldLoadModuleConfigurationOverrideBasedir/project/module_2/sonar-project.properties
new file mode 100644
index 0000000..c9516bc
--- /dev/null
+++ b/src/test/resources/org/sonarsource/scanner/cli/ConfTest/shouldLoadModuleConfigurationOverrideBasedir/project/module_2/sonar-project.properties
@@ -0,0 +1 @@
+sonar.projectName=Wrong name
diff --git a/src/test/resources/org/sonarsource/scanner/cli/ConfTest/shouldLoadModuleConfigurationWithoutRootConf/project/module1/sonar-project.properties b/src/test/resources/org/sonarsource/scanner/cli/ConfTest/shouldLoadModuleConfigurationWithoutRootConf/project/module1/sonar-project.properties
new file mode 100644
index 0000000..6803263
--- /dev/null
+++ b/src/test/resources/org/sonarsource/scanner/cli/ConfTest/shouldLoadModuleConfigurationWithoutRootConf/project/module1/sonar-project.properties
@@ -0,0 +1 @@
+sonar.projectName=Module 1
diff --git a/src/test/resources/org/sonarsource/scanner/cli/ConfTest/shouldLoadModuleConfigurationWithoutRootConf/project/module2/sonar-project.properties b/src/test/resources/org/sonarsource/scanner/cli/ConfTest/shouldLoadModuleConfigurationWithoutRootConf/project/module2/sonar-project.properties
new file mode 100644
index 0000000..c12fad8
--- /dev/null
+++ b/src/test/resources/org/sonarsource/scanner/cli/ConfTest/shouldLoadModuleConfigurationWithoutRootConf/project/module2/sonar-project.properties
@@ -0,0 +1 @@
+sonar.projectName=Module 2