Wie kann ich testen mit DBUnit mit reinem JDBC und Datenbank HSQLDB, ohne mit einem NoSuchTableException?

Ich versuche, mit DBUnit mit reinem JDBC und Datenbank HSQLDB, und kann nicht ganz, dass es funktioniert-obwohl ich verwendet habe, DBUnit mit Hibernate früher mit großem Erfolg. Hier ist der code:

import java.sql.PreparedStatement;
import org.dbunit.IDatabaseTester;
import org.dbunit.JdbcDatabaseTester;
import org.dbunit.dataset.IDataSet;
import org.dbunit.dataset.xml.XmlDataSet;
import org.junit.Test;

public class DummyTest {

    @Test
    public void testDBUnit() throws Exception {
        IDatabaseTester databaseTester = new JdbcDatabaseTester("org.hsqldb.jdbcDriver", "jdbc:hsqldb:mem", "sa", "");
        IDataSet dataSet = new XmlDataSet(getClass().getResourceAsStream("dataset.xml"));
        databaseTester.setDataSet(dataSet);
        databaseTester.onSetup();
        PreparedStatement pst = databaseTester.getConnection().getConnection().prepareStatement("select * from mytable");
    }
}

- Und dies ist die dataset.xml in Frage:

<dataset>
    <table name="mytable">
        <column>itemnumber</column>
        <column>something</column>
        <column>other</column>
        <row>
            <value>1234abcd</value>
            <value>something1</value>
            <value>else1</value>
        </row>
    </table>
</dataset>

Dieser test gibt mir ein NoSuchTableException:

org.dbunit.dataset.NoSuchTableException: mytable
    at org.dbunit.database.DatabaseDataSet.getTableMetaData(DatabaseDataSet.java:282)
    at org.dbunit.operation.DeleteAllOperation.execute(DeleteAllOperation.java:109)
    at org.dbunit.operation.CompositeOperation.execute(CompositeOperation.java:79)
    at org.dbunit.AbstractDatabaseTester.executeOperation(AbstractDatabaseTester.java:190)
    at org.dbunit.AbstractDatabaseTester.onSetup(AbstractDatabaseTester.java:103)
    at DummyTest.testDBUnit(DummyTest.java:18)

Wenn ich entfernen Sie die databaseTester.onSetup () - Zeile, bekomme ich eine SQLException statt:

java.sql.SQLException: Table not found in statement [select * from mytable]
    at org.hsqldb.jdbc.Util.throwError(Unknown Source)
    at org.hsqldb.jdbc.jdbcPreparedStatement.<init>(Unknown Source)
    at org.hsqldb.jdbc.jdbcConnection.prepareStatement(Unknown Source)
    at DummyTest.testDBUnit(DummyTest.java:19)

Dataset an sich arbeiten, da kann ich darauf zugreifen, wie es sein sollte:

ITable table = dataSet.getTable("mytable");
String firstCol = table.getTableMetaData().getColumns()[0];
String tName = table.getTableMetaData().getTableName();

Was vermisse ich hier?

BEARBEITEN: @mlk Punkte aus, DBUnit keine Tabellen erstellen. Wenn ich legen Sie die folgenden, bevor Sie den dataset, geht alles reibungslos:

PreparedStatement pp = databaseTester.getConnection().getConnection().prepareStatement(
     "create table mytable ( itemnumber varchar(255) NOT NULL primary key, "
   + " something varchar(255), other varchar(255) )");
pp.executeUpdate();

Ich habe eine follow-up Frage Gibt es eine Möglichkeit für DBUnit automatisch zu erstellen, Tabellen aus einem dataset oder einer dtd?

InformationsquelleAutor der Frage neu242 | 2009-10-07

Schreibe einen Kommentar