aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-application
diff options
context:
space:
mode:
Diffstat (limited to 'sonar-application')
-rw-r--r--sonar-application/src/main/java/org/sonar/application/Env.java12
-rw-r--r--sonar-application/src/test/java/org/sonar/application/EnvTest.java19
-rw-r--r--sonar-application/src/test/java/org/sonar/application/StartServerTest.java4
3 files changed, 27 insertions, 8 deletions
diff --git a/sonar-application/src/main/java/org/sonar/application/Env.java b/sonar-application/src/main/java/org/sonar/application/Env.java
index 53f25a9b8d7..168664f0d0a 100644
--- a/sonar-application/src/main/java/org/sonar/application/Env.java
+++ b/sonar-application/src/main/java/org/sonar/application/Env.java
@@ -24,17 +24,23 @@ import org.apache.commons.io.FileUtils;
import java.io.File;
import java.io.IOException;
import java.net.URISyntaxException;
+import java.net.URL;
class Env {
+ static final String ERROR_MESSAGE = "Do not copy-paste the configuration files (conf directory) from the old version. Update the content of the new files instead.";
private final File confFile;
- Env(File confFile) {
- this.confFile = confFile;
+ // visible for testing
+ Env(URL confUrl) throws URISyntaxException {
+ if (confUrl == null) {
+ throw new IllegalStateException(ERROR_MESSAGE);
+ }
+ this.confFile = new File(confUrl.toURI());
}
Env() throws URISyntaxException {
- this(new File(Env.class.getResource("/sonar.properties").toURI()));
+ this(Env.class.getResource("/sonar.properties"));
}
File rootDir() {
diff --git a/sonar-application/src/test/java/org/sonar/application/EnvTest.java b/sonar-application/src/test/java/org/sonar/application/EnvTest.java
index 27749840297..1400cc8f4ee 100644
--- a/sonar-application/src/test/java/org/sonar/application/EnvTest.java
+++ b/sonar-application/src/test/java/org/sonar/application/EnvTest.java
@@ -27,6 +27,7 @@ import org.junit.rules.TemporaryFolder;
import java.io.File;
import static org.fest.assertions.Assertions.assertThat;
+import static org.fest.assertions.Fail.fail;
public class EnvTest {
@@ -48,7 +49,7 @@ public class EnvTest {
FileUtils.touch(confFile);
FileUtils.touch(logFile);
- Env env = new Env(confFile);
+ Env env = new Env(confFile.toURL());
assertThat(env.rootDir()).isDirectory().exists().isEqualTo(home);
assertThat(env.file("conf/sonar.properties")).isFile().exists().isEqualTo(confFile);
@@ -65,7 +66,7 @@ public class EnvTest {
FileUtils.touch(confFile);
FileUtils.touch(logFile);
- Env env = new Env(confFile);
+ Env env = new Env(confFile.toURL());
File data = env.freshDir("data/h2");
assertThat(data).isDirectory().exists();
@@ -80,7 +81,19 @@ public class EnvTest {
@Test
public void temp_dir_should_be_writable() throws Exception {
- new Env(temp.newFile()).verifyWritableTempDir();
+ new Env(temp.newFile().toURL()).verifyWritableTempDir();
// do not fail
}
+
+ @Test
+ public void fail_if_conf_file_not_found() throws Exception {
+ try {
+ // note that "new Env(null)" would be exact, but let's
+ // keep "new Env()" for increasing code coverage :-)
+ new Env();
+ fail();
+ } catch (IllegalStateException e) {
+ assertThat(e).hasMessage(Env.ERROR_MESSAGE);
+ }
+ }
}
diff --git a/sonar-application/src/test/java/org/sonar/application/StartServerTest.java b/sonar-application/src/test/java/org/sonar/application/StartServerTest.java
index 1a7c9b7e769..590385d939a 100644
--- a/sonar-application/src/test/java/org/sonar/application/StartServerTest.java
+++ b/sonar-application/src/test/java/org/sonar/application/StartServerTest.java
@@ -41,7 +41,7 @@ public class StartServerTest {
public TemporaryFolder temp = new TemporaryFolder();
@Before
- public void prepare_app() throws IOException {
+ public void prepare_app() throws Exception {
File confFile = new File("src/test/fake-app/conf/sonar.properties");
if (!confFile.exists()) {
confFile = new File("sonar-application/src/test/fake-app/conf/sonar.properties");
@@ -49,7 +49,7 @@ public class StartServerTest {
File rootDir = temp.newFolder();
FileUtils.copyDirectory(confFile.getParentFile().getParentFile(), rootDir);
- env = new Env(new File(rootDir, "conf/sonar.properties"));
+ env = new Env(new File(rootDir, "conf/sonar.properties").toURL());
starter = new StartServer(env);
}