aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-server
diff options
context:
space:
mode:
authorSimon Brandhof <simon.brandhof@gmail.com>2011-09-14 19:27:32 +0200
committerSimon Brandhof <simon.brandhof@gmail.com>2011-09-14 19:27:32 +0200
commit98c747197edd93d800154459cf6596f7eafe0f32 (patch)
treef9efe0180b15f8aef17664fcddceb7fa819ec9e5 /sonar-server
parent413956912612804c89076b9f73f8aa35d9954ad8 (diff)
downloadsonarqube-98c747197edd93d800154459cf6596f7eafe0f32.tar.gz
sonarqube-98c747197edd93d800154459cf6596f7eafe0f32.zip
SONAR-2810 End support of JNDI JDBC datasource by WAR mode
Diffstat (limited to 'sonar-server')
-rw-r--r--sonar-server/src/main/java/org/sonar/server/database/JndiDatabaseConnector.java47
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/config/database.yml9
-rw-r--r--sonar-server/src/test/java/org/sonar/server/database/JndiDatabaseConnectorTest.java47
3 files changed, 7 insertions, 96 deletions
diff --git a/sonar-server/src/main/java/org/sonar/server/database/JndiDatabaseConnector.java b/sonar-server/src/main/java/org/sonar/server/database/JndiDatabaseConnector.java
index 581f8ae6361..abcb18f9a4c 100644
--- a/sonar-server/src/main/java/org/sonar/server/database/JndiDatabaseConnector.java
+++ b/sonar-server/src/main/java/org/sonar/server/database/JndiDatabaseConnector.java
@@ -21,17 +21,12 @@ package org.sonar.server.database;
import org.apache.commons.configuration.Configuration;
import org.apache.commons.dbcp.BasicDataSourceFactory;
-import org.apache.commons.lang.StringUtils;
import org.hibernate.cfg.Environment;
-import org.sonar.api.database.DatabaseProperties;
import org.sonar.api.utils.Logs;
import org.sonar.api.utils.SonarException;
import org.sonar.jpa.entity.SchemaMigration;
import org.sonar.jpa.session.AbstractDatabaseConnector;
-import javax.naming.Context;
-import javax.naming.InitialContext;
-import javax.naming.NamingException;
import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.SQLException;
@@ -40,13 +35,10 @@ import java.util.Properties;
public class JndiDatabaseConnector extends AbstractDatabaseConnector {
- static final String JNDI_ENV_CONTEXT = "java:comp/env";
private DataSource datasource = null;
- private String jndiKey;
public JndiDatabaseConnector(Configuration configuration) {
super(configuration, false);
- jndiKey = getConfiguration().getString(DatabaseProperties.PROP_JNDI_NAME);
}
@Override
@@ -62,11 +54,7 @@ public class JndiDatabaseConnector extends AbstractDatabaseConnector {
@Override
public void start() {
if (!isStarted()) {
- if (StringUtils.isNotBlank(jndiKey)) {
- loadJndiDatasource();
- } else {
- createDatasource();
- }
+ createDatasource();
}
if (!super.isOperational()) {
super.start();
@@ -80,37 +68,12 @@ public class JndiDatabaseConnector extends AbstractDatabaseConnector {
}
- private void loadJndiDatasource() {
- Context ctx;
- try {
- ctx = new InitialContext();
-
- } catch (NamingException e) {
- throw new SonarException("Can not instantiate JNDI context", e);
- }
-
- try {
- Context envCtx = (Context) ctx.lookup(JNDI_ENV_CONTEXT);
- datasource = (DataSource) envCtx.lookup(jndiKey);
- Logs.INFO.info("JDBC datasource loaded from JNDI: " + jndiKey);
-
- } catch (NamingException e) {
- throw new SonarException("JNDI context of JDBC datasource not found: " + jndiKey, e);
-
- } finally {
- try {
- ctx.close();
- } catch (NamingException e) {
- }
- }
- }
-
private void createDatasource() {
try {
Logs.INFO.info("Creating JDBC datasource");
Properties properties = new Properties();
Configuration dsConfig = getConfiguration().subset("sonar.jdbc");
- for (Iterator<String> it = dsConfig.getKeys(); it.hasNext();) {
+ for (Iterator<String> it = dsConfig.getKeys(); it.hasNext(); ) {
String key = it.next();
properties.setProperty(key, dsConfig.getString(key));
}
@@ -139,11 +102,7 @@ public class JndiDatabaseConnector extends AbstractDatabaseConnector {
@Override
public void setupEntityManagerFactory(Properties factoryProps) {
- if (StringUtils.isNotBlank(jndiKey)) {
- factoryProps.put(Environment.DATASOURCE, JNDI_ENV_CONTEXT + "/" + jndiKey);
- } else {
- factoryProps.put(Environment.CONNECTION_PROVIDER, CustomHibernateConnectionProvider.class.getName());
- }
+ factoryProps.put(Environment.CONNECTION_PROVIDER, CustomHibernateConnectionProvider.class.getName());
}
} \ No newline at end of file
diff --git a/sonar-server/src/main/webapp/WEB-INF/config/database.yml b/sonar-server/src/main/webapp/WEB-INF/config/database.yml
index 7b755e4b2ba..fe16fdbd96e 100644
--- a/sonar-server/src/main/webapp/WEB-INF/config/database.yml
+++ b/sonar-server/src/main/webapp/WEB-INF/config/database.yml
@@ -1,17 +1,8 @@
base: &base
adapter: <%= ::Java::OrgSonarServerUi::JRubyFacade.getInstance().getDialect().getActiveRecordJdbcAdapter() %>
-<%
- jndi_name = ::Java::OrgSonarServerUi::JRubyFacade.getInstance().getConfigurationValue('sonar.jdbc.jndiName')
- unless jndi_name
-%>
- # JDBC settings
username: <%= ::Java::OrgSonarServerUi::JRubyFacade.getInstance().getConfigurationValue('sonar.jdbc.username' ) || 'sonar' %>
password: <%= ::Java::OrgSonarServerUi::JRubyFacade.getInstance().getConfigurationValue('sonar.jdbc.password') || 'sonar' %>
url: <%= ::Java::OrgSonarServerUi::JRubyFacade.getInstance().getConfigurationValue('sonar.jdbc.url') %>
-<%
- end
-%>
- # Generic settings
dialect: <%= ::Java::OrgSonarServerUi::JRubyFacade.getInstance().getDialect().getActiveRecordDialectCode() %>
driver: <%= ::Java::OrgSonarServerUi::JRubyFacade.getInstance().getConfigurationValue('sonar.jdbc.driverClassName') %>
pool: <%= ::Java::OrgSonarServerUi::JRubyFacade.getInstance().getConfigurationValue('sonar.jdbc.maxActive') || 10 %>
diff --git a/sonar-server/src/test/java/org/sonar/server/database/JndiDatabaseConnectorTest.java b/sonar-server/src/test/java/org/sonar/server/database/JndiDatabaseConnectorTest.java
index 37e28fb7b5d..e3874c385af 100644
--- a/sonar-server/src/test/java/org/sonar/server/database/JndiDatabaseConnectorTest.java
+++ b/sonar-server/src/test/java/org/sonar/server/database/JndiDatabaseConnectorTest.java
@@ -28,31 +28,25 @@ import org.sonar.api.database.DatabaseProperties;
import org.sonar.jpa.entity.SchemaMigration;
import javax.naming.Context;
-import javax.naming.spi.InitialContextFactory;
import javax.persistence.EntityManagerFactory;
-import javax.sql.DataSource;
-import java.sql.Connection;
-import java.sql.DatabaseMetaData;
-import java.util.Hashtable;
import static org.junit.Assert.assertEquals;
-import static org.mockito.Mockito.*;
+import static org.mockito.Mockito.mock;
public class JndiDatabaseConnectorTest {
- private Configuration conf;
private String currentInitialContextFacto;
private JndiDatabaseConnector connector;
private int emfCreationCounter;
@Before
public void setup() {
- conf = new PropertiesConfiguration();
- conf.setProperty(DatabaseProperties.PROP_JNDI_NAME, "jdbc/sonar");
+ Configuration conf = new PropertiesConfiguration();
conf.setProperty(DatabaseProperties.PROP_DIALECT, DatabaseProperties.DIALECT_HSQLDB);
+ conf.setProperty(DatabaseProperties.PROP_URL, "jdbc:hsqldb:mem:sonar");
+ conf.setProperty(DatabaseProperties.PROP_DRIVER, "org.hsqldb.jdbcDriver");
currentInitialContextFacto = System.getProperty(Context.INITIAL_CONTEXT_FACTORY);
connector = getTestJndiConnector(conf);
- System.setProperty(Context.INITIAL_CONTEXT_FACTORY, TestInitialContextFactory.class.getName());
}
@After
@@ -75,16 +69,6 @@ public class JndiDatabaseConnectorTest {
assertEquals(2, emfCreationCounter);
}
- @Test
- public void transactionIsolationCorrectlySet() throws Exception {
- int fakeTransactionIsolation = 9;
- conf.setProperty(DatabaseProperties.PROP_ISOLATION, fakeTransactionIsolation);
- connector.start();
- Connection c = connector.getConnection();
- // start method call get a connection to test it, so total number is 2
- verify(c, times(2)).setTransactionIsolation(fakeTransactionIsolation);
- }
-
private JndiDatabaseConnector getTestJndiConnector(Configuration conf) {
JndiDatabaseConnector connector = new JndiDatabaseConnector(conf) {
@Override
@@ -102,28 +86,5 @@ public class JndiDatabaseConnectorTest {
return connector;
}
- public static class TestInitialContextFactory implements InitialContextFactory {
-
- private Connection c;
-
- public Context getInitialContext(Hashtable env) {
- Context envContext = mock(Context.class);
- Context context = mock(Context.class);
- DataSource ds = mock(DataSource.class);
- DatabaseMetaData m = mock(DatabaseMetaData.class);
- c = mock(Connection.class);
- try {
- when(envContext.lookup(JndiDatabaseConnector.JNDI_ENV_CONTEXT)).thenReturn(context);
- when(context.lookup("jdbc/sonar")).thenReturn(ds);
- when(ds.getConnection()).thenReturn(c);
- when(m.getURL()).thenReturn("jdbc:test");
- when(c.getMetaData()).thenReturn(m);
- } catch (Exception e) {
- throw new RuntimeException(e);
- }
-
- return envContext;
- }
- }
}