summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sonar-application/src/main/assembly/conf/wrapper.conf9
-rw-r--r--sonar-batch/src/main/java/org/sonar/batch/bootstrap/JdbcDriverHolder.java39
-rw-r--r--sonar-batch/src/test/java/org/sonar/batch/bootstrap/JdbcDriverHolderTest.java26
-rw-r--r--sonar-server/src/main/java/org/sonar/server/platform/DefaultServerFileSystem.java10
-rw-r--r--sonar-server/src/main/java/org/sonar/server/startup/JdbcDriverDeployer.java31
-rw-r--r--sonar-server/src/test/java/org/sonar/server/platform/DefaultServerFileSystemTest.java39
-rw-r--r--sonar-server/src/test/java/org/sonar/server/startup/JdbcDriverDeployerTest.java33
7 files changed, 132 insertions, 55 deletions
diff --git a/sonar-application/src/main/assembly/conf/wrapper.conf b/sonar-application/src/main/assembly/conf/wrapper.conf
index 9353b41cd83..d53aa251978 100644
--- a/sonar-application/src/main/assembly/conf/wrapper.conf
+++ b/sonar-application/src/main/assembly/conf/wrapper.conf
@@ -33,11 +33,10 @@ wrapper.java.mainclass=org.tanukisoftware.wrapper.WrapperSimpleApp
# needed starting from 1
wrapper.java.classpath.1=../../lib/*.jar
wrapper.java.classpath.2=../../conf
-wrapper.java.classpath.3=../../extensions/jdbc-driver/h2/*.jar
-wrapper.java.classpath.4=../../extensions/jdbc-driver/mysql/*.jar
-wrapper.java.classpath.5=../../extensions/jdbc-driver/oracle/*.jar
-wrapper.java.classpath.6=../../extensions/jdbc-driver/postgresql/*.jar
-wrapper.java.classpath.7=../../extensions/jdbc-driver/mssql/*.jar
+wrapper.java.classpath.3=../../extensions/jdbc-driver/mysql/*.jar
+wrapper.java.classpath.4=../../extensions/jdbc-driver/oracle/*.jar
+wrapper.java.classpath.5=../../extensions/jdbc-driver/postgresql/*.jar
+wrapper.java.classpath.6=../../extensions/jdbc-driver/mssql/*.jar
# Java Library Path (location of Wrapper.DLL or libwrapper.so)
wrapper.java.library.path.1=./lib
diff --git a/sonar-batch/src/main/java/org/sonar/batch/bootstrap/JdbcDriverHolder.java b/sonar-batch/src/main/java/org/sonar/batch/bootstrap/JdbcDriverHolder.java
index 614841858ca..437fd62ff55 100644
--- a/sonar-batch/src/main/java/org/sonar/batch/bootstrap/JdbcDriverHolder.java
+++ b/sonar-batch/src/main/java/org/sonar/batch/bootstrap/JdbcDriverHolder.java
@@ -20,11 +20,14 @@
package org.sonar.batch.bootstrap;
import com.google.common.annotations.VisibleForTesting;
+import com.google.common.base.Strings;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.sonar.api.utils.SonarException;
import org.sonar.home.cache.FileCache;
+import javax.annotation.CheckForNull;
+
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
@@ -58,22 +61,23 @@ public class JdbcDriverHolder {
try {
LOG.info("Install JDBC driver");
String[] nameAndHash = downloadJdbcDriverIndex();
- String filename = nameAndHash[0];
- String hash = nameAndHash[1];
-
- File jdbcDriver = fileCache.get(filename, hash, new FileCache.Downloader() {
- public void download(String filename, File toFile) throws IOException {
- String url = "/deploy/" + filename;
- if (LOG.isDebugEnabled()) {
- LOG.debug("Download {} to {}", url, toFile.getAbsolutePath());
- } else {
- LOG.info("Download {}", filename);
+ if (nameAndHash != null) {
+ String filename = nameAndHash[0];
+ String hash = nameAndHash[1];
+
+ File jdbcDriver = fileCache.get(filename, hash, new FileCache.Downloader() {
+ public void download(String filename, File toFile) throws IOException {
+ String url = "/deploy/" + filename;
+ if (LOG.isDebugEnabled()) {
+ LOG.debug("Download {} to {}", url, toFile.getAbsolutePath());
+ } else {
+ LOG.info("Download {}", filename);
+ }
+ serverClient.download(url, toFile);
}
- serverClient.download(url, toFile);
- }
- });
-
- classLoader = initClassloader(jdbcDriver);
+ });
+ classLoader = initClassloader(jdbcDriver);
+ }
} catch (SonarException e) {
throw e;
} catch (Exception e) {
@@ -134,11 +138,16 @@ public class JdbcDriverHolder {
}
}
+ @CheckForNull
private String[] downloadJdbcDriverIndex() {
String url = "/deploy/jdbc-driver.txt";
try {
LOG.debug("Download index of jdbc-driver");
String indexContent = serverClient.request(url);
+ // File is empty when H2 is used
+ if (Strings.isNullOrEmpty(indexContent)) {
+ return null;
+ }
return indexContent.split("\\|");
} catch (Exception e) {
throw new SonarException("Fail to download jdbc-driver index: " + url, e);
diff --git a/sonar-batch/src/test/java/org/sonar/batch/bootstrap/JdbcDriverHolderTest.java b/sonar-batch/src/test/java/org/sonar/batch/bootstrap/JdbcDriverHolderTest.java
index aece0a8f370..3d3dcad38db 100644
--- a/sonar-batch/src/test/java/org/sonar/batch/bootstrap/JdbcDriverHolderTest.java
+++ b/sonar-batch/src/test/java/org/sonar/batch/bootstrap/JdbcDriverHolderTest.java
@@ -19,6 +19,7 @@
*/
package org.sonar.batch.bootstrap;
+import com.google.common.io.Resources;
import org.junit.After;
import org.junit.Before;
import org.junit.Rule;
@@ -32,9 +33,7 @@ import java.io.File;
import static org.fest.assertions.Assertions.assertThat;
import static org.mockito.Matchers.any;
import static org.mockito.Matchers.eq;
-import static org.mockito.Mockito.mock;
-import static org.mockito.Mockito.verifyZeroInteractions;
-import static org.mockito.Mockito.when;
+import static org.mockito.Mockito.*;
public class JdbcDriverHolderTest {
@@ -59,10 +58,10 @@ public class JdbcDriverHolderTest {
}
@Test
- public void should_extend_classloader_with_jdbc_driver() throws Exception {
+ public void extend_classloader_with_jdbc_driver() throws Exception {
FileCache cache = mock(FileCache.class);
- File fakeDriver = new File(getClass().getResource("/org/sonar/batch/bootstrap/JdbcDriverHolderTest/jdbc-driver.jar").toURI());
+ File fakeDriver = new File(Resources.getResource(JdbcDriverHolderTest.class, "JdbcDriverHolderTest/jdbc-driver.jar").getFile());
when(cache.get(eq("ojdbc14.jar"), eq("fakemd5"), any(FileCache.Downloader.class))).thenReturn(fakeDriver);
/* jdbc-driver.jar has just one file /foo/foo.txt */
@@ -85,7 +84,22 @@ public class JdbcDriverHolderTest {
}
@Test
- public void should_be_disabled_if_preview() {
+ public void do_nothing_when_jdbc_driver_file_is_empty() throws Exception {
+ FileCache cache = mock(FileCache.class);
+
+ ServerClient server = mock(ServerClient.class);
+ when(server.request("/deploy/jdbc-driver.txt")).thenReturn("");
+
+ JdbcDriverHolder holder = new JdbcDriverHolder(cache, mode, server);
+ holder.start();
+
+ verify(server, never()).download(anyString(), any(File.class));
+ verifyZeroInteractions(cache);
+ assertThat(holder.getClassLoader()).isNull();
+ }
+
+ @Test
+ public void be_disabled_if_preview() {
FileCache cache = mock(FileCache.class);
when(mode.isPreview()).thenReturn(true);
ServerClient server = mock(ServerClient.class);
diff --git a/sonar-server/src/main/java/org/sonar/server/platform/DefaultServerFileSystem.java b/sonar-server/src/main/java/org/sonar/server/platform/DefaultServerFileSystem.java
index cf7a2d6ac0f..9932eda1aad 100644
--- a/sonar-server/src/main/java/org/sonar/server/platform/DefaultServerFileSystem.java
+++ b/sonar-server/src/main/java/org/sonar/server/platform/DefaultServerFileSystem.java
@@ -29,6 +29,9 @@ import org.sonar.api.config.Settings;
import org.sonar.api.platform.Server;
import org.sonar.api.platform.ServerFileSystem;
import org.sonar.core.persistence.Database;
+import org.sonar.core.persistence.dialect.H2;
+
+import javax.annotation.CheckForNull;
import java.io.File;
import java.io.FileFilter;
@@ -132,8 +135,15 @@ public class DefaultServerFileSystem implements ServerFileSystem, Startable {
return new File(getHomeDir(), "extensions/trash");
}
+ /**
+ * Return null when database is H2, as batch is already containing H2 jar
+ */
+ @CheckForNull
public File getJdbcDriver() {
String dialect = database.getDialect().getId();
+ if (H2.ID.equals(dialect)) {
+ return null;
+ }
File dir = new File(getHomeDir(), "/extensions/jdbc-driver/" + dialect + "/");
List<File> jars = getFiles(dir, "jar");
if (jars.isEmpty()) {
diff --git a/sonar-server/src/main/java/org/sonar/server/startup/JdbcDriverDeployer.java b/sonar-server/src/main/java/org/sonar/server/startup/JdbcDriverDeployer.java
index 141cc2e1261..bb8ee65f373 100644
--- a/sonar-server/src/main/java/org/sonar/server/startup/JdbcDriverDeployer.java
+++ b/sonar-server/src/main/java/org/sonar/server/startup/JdbcDriverDeployer.java
@@ -23,6 +23,8 @@ import org.apache.commons.io.FileUtils;
import org.sonar.home.cache.FileHashes;
import org.sonar.server.platform.DefaultServerFileSystem;
+import javax.annotation.Nullable;
+
import java.io.File;
import java.io.IOException;
@@ -35,22 +37,35 @@ public class JdbcDriverDeployer {
}
public void start() {
+ File deployedDriver = null;
File driver = fileSystem.getJdbcDriver();
- File deployedDriver = new File(fileSystem.getDeployDir(), driver.getName());
- if (!deployedDriver.exists() || deployedDriver.length() != driver.length()) {
- try {
- FileUtils.copyFile(driver, deployedDriver);
+ // Driver can be null for H2, in that case we write an empty jdbc-driver.txt file
+ if (driver != null) {
+ deployedDriver = new File(fileSystem.getDeployDir(), driver.getName());
+ if (!deployedDriver.exists() || deployedDriver.length() != driver.length()) {
+ try {
+ FileUtils.copyFile(driver, deployedDriver);
- } catch (IOException e) {
- throw new IllegalStateException("Can not copy the JDBC driver from " + driver + " to " + deployedDriver, e);
+ } catch (IOException e) {
+ throw new IllegalStateException("Can not copy the JDBC driver from " + driver + " to " + deployedDriver, e);
+ }
}
}
+
File deployedDriverIndex = fileSystem.getDeployedJdbcDriverIndex();
try {
- String hash = new FileHashes().of(deployedDriver);
- FileUtils.writeStringToFile(deployedDriverIndex, deployedDriver.getName() + "|" + hash);
+ FileUtils.writeStringToFile(deployedDriverIndex, driverIndexContent(deployedDriver));
} catch (IOException e) {
throw new IllegalStateException("Can not generate index of JDBC driver", e);
}
}
+
+ private String driverIndexContent(@Nullable File deployedDriver){
+ if (deployedDriver != null) {
+ String hash = new FileHashes().of(deployedDriver);
+ return deployedDriver.getName() + "|" + hash;
+ }
+ return "";
+ }
+
}
diff --git a/sonar-server/src/test/java/org/sonar/server/platform/DefaultServerFileSystemTest.java b/sonar-server/src/test/java/org/sonar/server/platform/DefaultServerFileSystemTest.java
index dd97bd9b638..8f22e23a815 100644
--- a/sonar-server/src/test/java/org/sonar/server/platform/DefaultServerFileSystemTest.java
+++ b/sonar-server/src/test/java/org/sonar/server/platform/DefaultServerFileSystemTest.java
@@ -23,14 +23,14 @@ import org.junit.Test;
import org.sonar.api.platform.ServerFileSystem;
import org.sonar.core.persistence.Database;
import org.sonar.core.persistence.dialect.Dialect;
+import org.sonar.core.persistence.dialect.H2;
import org.sonar.core.persistence.dialect.MySql;
import org.sonar.test.TestUtils;
import java.io.File;
import java.util.List;
-import static junit.framework.Assert.assertNotNull;
-import static org.junit.Assert.assertEquals;
+import static org.fest.assertions.Assertions.assertThat;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
@@ -39,15 +39,22 @@ public class DefaultServerFileSystemTest {
private static final String PATH = "/org/sonar/server/platform/DefaultServerFileSystemTest/";
@Test
- public void testGetJdbcDriver() {
+ public void get_jdbc_driver() {
Database database = mock(Database.class);
when(database.getDialect()).thenReturn(new MySql());
File driver = new DefaultServerFileSystem(database, TestUtils.getResource(PATH + "testGetJdbcDriver"), null).getJdbcDriver();
- assertNotNull(driver);
+ assertThat(driver).isNotNull();
+ }
+
+ @Test
+ public void get_jdbc_driver_return_null_when_h2() {
+ Database database = mock(Database.class);
+ when(database.getDialect()).thenReturn(new H2());
+ assertThat(new DefaultServerFileSystem(database, (File) null, null).getJdbcDriver()).isNull();
}
@Test(expected = IllegalStateException.class)
- public void failIfJdbcDriverNotFound() {
+ public void fail_if_jdbc_driver_not_found() {
Database database = mock(Database.class);
Dialect fakeDialect = mock(Dialect.class);
@@ -58,40 +65,40 @@ public class DefaultServerFileSystemTest {
}
@Test
- public void shouldFindPlugins() {
+ public void find_plugins() {
List<File> plugins = new DefaultServerFileSystem(null, TestUtils.getResource(PATH + "shouldFindPlugins"), null).getUserPlugins();
- assertEquals(2, plugins.size());
+ assertThat(plugins).hasSize(2);
}
@Test
- public void shouldNotFailIfNoPlugins() {
+ public void not_fail_if_no_plugins() {
List<File> plugins = new DefaultServerFileSystem(null, TestUtils.getResource(PATH + "shouldNotFailIfNoPlugins"), null).getUserPlugins();
- assertEquals(0, plugins.size());
+ assertThat(plugins).isEmpty();
}
@Test
- public void shouldFindCheckstyleExtensions() {
+ public void find_checkstyle_extensions() {
ServerFileSystem fs = new DefaultServerFileSystem(null, TestUtils.getResource(PATH + "shouldFindCheckstyleExtensions"), null);
List<File> xmls = fs.getExtensions("checkstyle", "xml");
- assertEquals(1, xmls.size());
+ assertThat(xmls).hasSize(1);
List<File> all = fs.getExtensions("checkstyle");
- assertEquals(3, all.size());
+ assertThat(all).hasSize(3);
}
@Test
- public void shouldNotFailIfNoCheckstyleExtensions() {
+ public void not_fail_if_no_checkstyle_extensions() {
ServerFileSystem fs = new DefaultServerFileSystem(null, TestUtils.getResource(PATH + "shouldNotFailIfNoCheckstyleExtensions"), null);
List<File> xmls = fs.getExtensions("checkstyle", "xml");
- assertEquals(0, xmls.size());
+ assertThat(xmls).isEmpty();
List<File> jars = fs.getExtensions("checkstyle");
- assertEquals(0, jars.size());
+ assertThat(jars).isEmpty();
}
@Test(expected = IllegalStateException.class)
- public void shouldFailIfHomeDirectoryNotExists() {
+ public void fail_if_home_directory_not_exists() {
DefaultServerFileSystem fs = new DefaultServerFileSystem(null, new File("/notexists"), null);
fs.start();
}
diff --git a/sonar-server/src/test/java/org/sonar/server/startup/JdbcDriverDeployerTest.java b/sonar-server/src/test/java/org/sonar/server/startup/JdbcDriverDeployerTest.java
index 3f85cf0c1a4..f03d4f86f77 100644
--- a/sonar-server/src/test/java/org/sonar/server/startup/JdbcDriverDeployerTest.java
+++ b/sonar-server/src/test/java/org/sonar/server/startup/JdbcDriverDeployerTest.java
@@ -19,8 +19,11 @@
*/
package org.sonar.server.startup;
-import org.apache.commons.io.FileUtils;
+import com.google.common.base.Charsets;
+import com.google.common.io.Files;
+import org.junit.Rule;
import org.junit.Test;
+import org.junit.rules.TemporaryFolder;
import org.sonar.server.platform.DefaultServerFileSystem;
import org.sonar.test.TestUtils;
@@ -32,13 +35,16 @@ import static org.mockito.Mockito.when;
public class JdbcDriverDeployerTest {
+ @Rule
+ public TemporaryFolder temp = new TemporaryFolder();
+
@Test
public void test_deploy() throws Exception {
DefaultServerFileSystem fs = mock(DefaultServerFileSystem.class);
File initialDriver = TestUtils.getResource(getClass(), "deploy/my-driver.jar");
when(fs.getJdbcDriver()).thenReturn(initialDriver);
- File deployDir = TestUtils.getTestTempDir(getClass(), "deploy", true);
+ File deployDir = temp.newFolder("deploy");
when(fs.getDeployDir()).thenReturn(deployDir);
File deployedIndex = new File(deployDir, "jdbc-driver.txt");
File deployedFile = new File(deployDir, "my-driver.jar");
@@ -46,12 +52,29 @@ public class JdbcDriverDeployerTest {
assertThat(deployedFile).doesNotExist();
when(fs.getDeployedJdbcDriverIndex()).thenReturn(deployedIndex);
- JdbcDriverDeployer deployer = new JdbcDriverDeployer(fs);
- deployer.start();
+ new JdbcDriverDeployer(fs).start();
assertThat(deployedIndex).exists();
assertThat(deployedFile).exists();
assertThat(deployedFile).hasSize(initialDriver.length());
- assertThat(FileUtils.readFileToString(deployedIndex)).isEqualTo("my-driver.jar|02b97f7bc37b2b68fc847fcc3fc1c156");
+
+ assertThat(Files.toString(deployedIndex, Charsets.UTF_8)).isEqualTo("my-driver.jar|02b97f7bc37b2b68fc847fcc3fc1c156");
+ }
+
+ @Test
+ public void create_empty_file_when_no_jdbc_driver() throws Exception {
+ DefaultServerFileSystem fs = mock(DefaultServerFileSystem.class);
+ when(fs.getJdbcDriver()).thenReturn(null);
+
+ File deployDir = temp.newFolder("deploy");
+ when(fs.getDeployDir()).thenReturn(deployDir);
+ File deployedIndex = new File(deployDir, "jdbc-driver.txt");
+ assertThat(deployedIndex).doesNotExist();
+ when(fs.getDeployedJdbcDriverIndex()).thenReturn(deployedIndex);
+
+ new JdbcDriverDeployer(fs).start();
+
+ assertThat(deployedIndex).exists();
+ assertThat(Files.toString(deployedIndex, Charsets.UTF_8)).isEqualTo("");
}
}