aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-testing-harness/src
diff options
context:
space:
mode:
authorEvgeny Mandrikov <mandrikov@gmail.com>2011-11-10 13:48:45 +0400
committerEvgeny Mandrikov <mandrikov@gmail.com>2011-11-10 15:25:31 +0400
commit30161cdacfd051bcf339fcc0b8c9ad1307370765 (patch)
tree6da21d592eeeabac429ee650b898f63a831c9f0c /sonar-testing-harness/src
parent56cf7e94818f872fda569945e145cb111afd6e22 (diff)
downloadsonarqube-30161cdacfd051bcf339fcc0b8c9ad1307370765.tar.gz
sonarqube-30161cdacfd051bcf339fcc0b8c9ad1307370765.zip
Use Derby for unit tests instead of HSQL, remove unused code
Diffstat (limited to 'sonar-testing-harness/src')
-rw-r--r--sonar-testing-harness/src/main/java/org/sonar/test/persistence/DatabaseTestCase.java259
1 files changed, 0 insertions, 259 deletions
diff --git a/sonar-testing-harness/src/main/java/org/sonar/test/persistence/DatabaseTestCase.java b/sonar-testing-harness/src/main/java/org/sonar/test/persistence/DatabaseTestCase.java
deleted file mode 100644
index 3e9577165d0..00000000000
--- a/sonar-testing-harness/src/main/java/org/sonar/test/persistence/DatabaseTestCase.java
+++ /dev/null
@@ -1,259 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-package org.sonar.test.persistence;
-
-import org.apache.commons.io.IOUtils;
-import org.apache.commons.lang.StringUtils;
-import org.apache.derby.jdbc.EmbeddedDriver;
-import org.dbunit.Assertion;
-import org.dbunit.DatabaseUnitException;
-import org.dbunit.IDatabaseTester;
-import org.dbunit.JdbcDatabaseTester;
-import org.dbunit.dataset.CompositeDataSet;
-import org.dbunit.dataset.DataSetException;
-import org.dbunit.dataset.IDataSet;
-import org.dbunit.dataset.ReplacementDataSet;
-import org.dbunit.dataset.xml.FlatXmlDataSet;
-import org.dbunit.operation.DatabaseOperation;
-import org.junit.After;
-import org.junit.AfterClass;
-import org.junit.Assert;
-import org.junit.BeforeClass;
-
-import java.io.InputStream;
-import java.sql.*;
-import java.util.List;
-
-import static org.junit.Assert.fail;
-
-public abstract class DatabaseTestCase {
-
- private static IDatabaseTester databaseTester = null;
- private static final String JDBC_URL = "jdbc:derby:memory:sonar";
- private Connection connection = null;
-
-
- @BeforeClass
- public static void startDatabase() throws Exception {
- System.setProperty("derby.stream.error.file", "target/derby.log");
-
- /*
- Note: we could use a datasource instead of a direct JDBC connection.
- See org.apache.derby.jdbc.ClientDataSource (http://db.apache.org/derby/papers/DerbyClientSpec.html#Connection+URL+Format)
- and org.dbunit.DataSourceDatabaseTester
- */
- EmbeddedDriver driver = new EmbeddedDriver();
- DriverManager.registerDriver(driver);
- databaseTester = new JdbcDatabaseTester(driver.getClass().getName(), JDBC_URL + ";create=true");
- createDatabase();
- }
-
- private static void createDatabase() throws Exception {
- Connection c = databaseTester.getConnection().getConnection();
- Statement st = c.createStatement();
- for (String ddl : loadDdlStatements()) {
- st.executeUpdate(ddl);
- c.commit();
- }
- st.close();
- c.close();
- }
-
- private static String[] loadDdlStatements() throws Exception {
- InputStream in = DatabaseTestCase.class.getResourceAsStream("/org/sonar/test/persistence/sonar-test.ddl");
- List<String> lines = IOUtils.readLines(in);
- StringBuilder ddl = new StringBuilder();
- for (String line : lines) {
- if (StringUtils.isNotBlank(line) && !StringUtils.startsWith(StringUtils.trimToEmpty(line), "#")) {
- ddl.append(line).append(" ");
- }
- }
-
- in.close();
- return StringUtils.split(StringUtils.trim(ddl.toString()), ";");
- }
-
- @AfterClass
- public static void stopDatabase() throws Exception {
- try {
- DriverManager.getConnection(JDBC_URL + ";drop=true");
- databaseTester.onTearDown();
- } catch (Exception e) {
- // silently fail
- }
- }
-
- public static IDatabaseTester getDatabaseTester() {
- return databaseTester;
- }
-
- protected final Connection getConnection() {
- try {
- if (connection == null) {
- connection = getDatabaseTester().getConnection().getConnection();
- }
-
- } catch (Exception e) {
- throw new RuntimeException(e);
- }
- return connection;
- }
-
- @After
- public final void truncateTables() throws SQLException {
- ResultSet rs = getConnection().getMetaData().getTables(null, "APP", null, null);
- Statement st = getConnection().createStatement();
- while (rs.next()) {
- String tableName = rs.getString(3);
- // truncate command is implemented since derby 10.7
- st.executeUpdate("TRUNCATE TABLE " + tableName);
- }
- st.close();
- rs.close();
- getConnection().commit();
- }
-
- @After
- public final void closeConnection() {
- if (connection != null) {
- try {
- connection.close();
- connection = null;
- } catch (SQLException e) {
- throw new RuntimeException(e);
- }
- }
- }
-
-
- protected final void setupData(String... testNames) {
- InputStream[] streams = new InputStream[testNames.length];
- try {
- for (int i = 0; i < testNames.length; i++) {
- String className = getClass().getName();
- className = String.format("/%s/%s.xml", className.replace(".", "/"), testNames[i]);
- streams[i] = getClass().getResourceAsStream(className);
- if (streams[i] == null) {
- throw new RuntimeException("Test not found :" + className);
- }
- }
-
- setupData(streams);
-
- } finally {
- for (InputStream stream : streams) {
- IOUtils.closeQuietly(stream);
- }
- }
- }
-
- private void setupData(InputStream... dataSetStream) {
- try {
- IDataSet[] dataSets = new IDataSet[dataSetStream.length];
- for (int i = 0; i < dataSetStream.length; i++) {
- ReplacementDataSet dataSet = new ReplacementDataSet(new FlatXmlDataSet(dataSetStream[i]));
- dataSet.addReplacementObject("[null]", null);
- dataSet.addReplacementObject("true", 1);
- dataSet.addReplacementObject("false", 0);
- dataSets[i] = dataSet;
- }
- CompositeDataSet compositeDataSet = new CompositeDataSet(dataSets);
- DatabaseOperation.CLEAN_INSERT.execute(getDatabaseTester().getConnection(), compositeDataSet);
-
- } catch (Exception e) {
- throw new RuntimeException("Could not setup DBUnit data", e);
- }
- }
-
- protected final void assertTables(String testName, String... tables) {
- try {
- IDataSet dataSet = getCurrentDataSet();
- IDataSet expectedDataSet = getExpectedData(testName);
- for (String table : tables) {
- Assertion.assertEquals(expectedDataSet.getTable(table), dataSet.getTable(table));
- }
- } catch (DataSetException e) {
- throw translateException("Error while checking results", e);
- } catch (DatabaseUnitException e) {
- fail(e.getMessage());
- }
- }
-
- protected final void assertTables(String testName, String[] tables, String[] ignoreCols) {
- try {
- IDataSet dataSet = getCurrentDataSet();
- IDataSet expectedDataSet = getExpectedData(testName);
- for (String table : tables) {
- Assertion.assertEqualsIgnoreCols(expectedDataSet.getTable(table), dataSet.getTable(table), ignoreCols);
- }
- } catch (DataSetException e) {
- throw translateException("Error while checking results", e);
- } catch (DatabaseUnitException e) {
- fail(e.getMessage());
- }
- }
-
- protected final void assertEmptyTables(String... emptyTables) {
- for (String table : emptyTables) {
- try {
- Assert.assertEquals(0, getCurrentDataSet().getTable(table).getRowCount());
- } catch (DataSetException e) {
- throw translateException("Error while checking results", e);
- }
- }
- }
-
- private IDataSet getExpectedData(String testName) {
- String className = getClass().getName();
- className = String.format("/%s/%s-result.xml", className.replace(".", "/"), testName);
-
- InputStream in = getClass().getResourceAsStream(className);
- try {
- return getData(in);
- } finally {
- IOUtils.closeQuietly(in);
- }
- }
-
- private IDataSet getData(InputStream stream) {
- try {
- ReplacementDataSet dataSet = new ReplacementDataSet(new FlatXmlDataSet(stream));
- dataSet.addReplacementObject("[null]", null);
- return dataSet;
- } catch (Exception e) {
- throw translateException("Could not read the dataset stream", e);
- }
- }
-
- private IDataSet getCurrentDataSet() {
- try {
- return databaseTester.getConnection().createDataSet();
- } catch (Exception e) {
- throw translateException("Could not create the current dataset", e);
- }
- }
-
- private static RuntimeException translateException(String msg, Exception cause) {
- RuntimeException runtimeException = new RuntimeException(String.format("%s: [%s] %s", msg, cause.getClass().getName(), cause.getMessage()));
- runtimeException.setStackTrace(cause.getStackTrace());
- return runtimeException;
- }
-
-}