aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSébastien Lesaint <sebastien.lesaint@sonarsource.com>2016-08-23 15:07:37 +0200
committerSébastien Lesaint <sebastien.lesaint@sonarsource.com>2016-08-24 10:20:24 +0200
commita79dddadd5038e9d6bbc26d363e39576180c1063 (patch)
tree26814a5085ab13b97b7e30a70d16fb9fac05c760
parentd94aa825004f0c8666690da143d466d71b31388d (diff)
downloadsonarqube-a79dddadd5038e9d6bbc26d363e39576180c1063.tar.gz
sonarqube-a79dddadd5038e9d6bbc26d363e39576180c1063.zip
SONAR-7896 set env var TMPDIR to make JRuby use SQ tmp dir for tmp files
these temp file are especially used when uploading
-rw-r--r--sonar-application/src/main/java/org/sonar/application/App.java2
-rw-r--r--sonar-application/src/test/java/org/sonar/application/AppTest.java16
2 files changed, 18 insertions, 0 deletions
diff --git a/sonar-application/src/main/java/org/sonar/application/App.java b/sonar-application/src/main/java/org/sonar/application/App.java
index 8c8d73529a8..75cb88a007c 100644
--- a/sonar-application/src/main/java/org/sonar/application/App.java
+++ b/sonar-application/src/main/java/org/sonar/application/App.java
@@ -92,6 +92,8 @@ public class App implements Stoppable {
.addJavaOptions(props.nonNullValue(ProcessProperties.WEB_JAVA_ADDITIONAL_OPTS))
// required for logback tomcat valve
.setEnvVariable(ProcessProperties.PATH_LOGS, props.nonNullValue(ProcessProperties.PATH_LOGS))
+ // ensure JRuby uses SQ's temp directory as temp directory (eg. for temp files used during HTTP uploads)
+ .setEnvVariable("TMPDIR", props.nonNullValue(ProcessProperties.PATH_TEMP))
.setClassName("org.sonar.server.app.WebServer")
.setArguments(props.rawProperties())
.addClasspath("./lib/common/*")
diff --git a/sonar-application/src/test/java/org/sonar/application/AppTest.java b/sonar-application/src/test/java/org/sonar/application/AppTest.java
index 8150639c865..2d9613a17cd 100644
--- a/sonar-application/src/test/java/org/sonar/application/AppTest.java
+++ b/sonar-application/src/test/java/org/sonar/application/AppTest.java
@@ -35,6 +35,7 @@ import org.sonar.process.monitor.JavaCommand;
import org.sonar.process.monitor.Monitor;
import static org.assertj.core.api.Assertions.assertThat;
+import static org.assertj.core.api.Assertions.entry;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.verify;
@@ -109,6 +110,21 @@ public class AppTest {
assertThat(argument.getValue().get(1).getClasspath()).contains("oracle/ojdbc6.jar");
}
+ @Test
+ public void sets_TMPDIR_env_var_of_Web_process() throws Exception {
+ Monitor monitor = mock(Monitor.class);
+ App app = new App(monitor);
+ Props props = initDefaultProps();
+ String expectedTmpDir = "expected tmp dir";
+ props.set("sonar.path.temp", expectedTmpDir);
+ app.start(props);
+
+ ArgumentCaptor<List<JavaCommand>> argument = newJavaCommandArgumentCaptor();
+ verify(monitor).start(argument.capture());
+
+ assertThat(argument.getValue().get(1).getEnvVariables()).contains(entry("TMPDIR", expectedTmpDir));
+ }
+
private Props initDefaultProps() throws IOException {
Props props = new Props(new Properties());
ProcessProperties.completeDefaults(props);