Commit b6385efb authored by Bruce Momjian's avatar Bruce Momjian

Attached is a patch that fixes 2 test cases of the JDBC test

suite. This reduces the number of failures from 9 to 7.

Both ConnectionTest and JBuilderTest did not create their own
tables, which caused these test cases to fail with "relation ...
does not exist". It appears these test cases relied on tables
created by the example code elsewhere in the source tree. I've
added the necessary "create table" and "drop table" statements
to the test cases, using the column definitions from the example
code.

While working on that I modified the helper method createTable
in JDBC2Tests.java to take a table parameter, rather than using
table names passed via the properties in build.xml. I'm not sure
what that was good for, and in fact, except for the default
table name "jdbctest", this functionality wasn't used at all.

Ren? Pijlman
parent 7066253a
...@@ -62,45 +62,34 @@ public class JDBC2Tests extends TestSuite { ...@@ -62,45 +62,34 @@ public class JDBC2Tests extends TestSuite {
/** /**
* Helper - creates a test table for use by a test * Helper - creates a test table for use by a test
*/ */
public static void createTable(Connection conn,String columns) { public static void createTable(
Connection conn, String table, String columns) {
try { try {
Statement st = conn.createStatement(); Statement st = conn.createStatement();
// Ignore the drop
try { try {
st.executeUpdate("drop table "+getTableName()); try {
st.executeUpdate("drop table " + table);
} catch(SQLException se) { } catch(SQLException se) {
// Intentionally ignore exception
} }
// Now create the table // Now create the table
st.executeUpdate("create table "+getTableName()+" ("+columns+")"); st.executeUpdate( "create table " + table + " (" + columns +
")" );
} finally {
st.close(); st.close();
}
} catch(SQLException ex) { } catch(SQLException ex) {
TestCase.assert(ex.getMessage(),false); TestCase.assert(ex.getMessage(),false);
} }
} }
/** // Create the test table whose name is passed via the properties
* Variant used when more than one table is required // (see ../../../build.xml). It appears that the original author of
*/ // this test suite intended to specify all test table names via the
public static void createTable(Connection conn,String id,String columns) { // properties, but this was never fully implemented.
try { public static void createTable(Connection conn, String columns) {
Statement st = conn.createStatement(); createTable(conn, getTableName(), columns);
// Ignore the drop
try {
st.executeUpdate("drop table "+getTableName(id));
} catch(SQLException se) {
}
// Now create the table
st.executeUpdate("create table "+getTableName(id)+" ("+columns+")");
st.close();
} catch(SQLException ex) {
TestCase.assert(ex.getMessage(),false);
}
} }
/** /**
......
...@@ -10,7 +10,7 @@ import java.sql.*; ...@@ -10,7 +10,7 @@ import java.sql.*;
* *
* PS: Do you know how difficult it is to type on a train? ;-) * PS: Do you know how difficult it is to type on a train? ;-)
* *
* $Id: ConnectionTest.java,v 1.2 2001/02/13 16:39:05 peter Exp $ * $Id: ConnectionTest.java,v 1.3 2001/09/07 22:17:48 momjian Exp $
*/ */
public class ConnectionTest extends TestCase { public class ConnectionTest extends TestCase {
...@@ -22,6 +22,30 @@ public class ConnectionTest extends TestCase { ...@@ -22,6 +22,30 @@ public class ConnectionTest extends TestCase {
super(name); super(name);
} }
// Set up the fixture for this testcase: the tables for this test.
protected void setUp() throws Exception {
Connection con = JDBC2Tests.openDB();
JDBC2Tests.createTable( con, "test_a",
"imagename name,image oid,id int4" );
JDBC2Tests.createTable( con, "test_c",
"source text,cost money,imageid int4" );
JDBC2Tests.closeDB(con);
}
// Tear down the fixture for this test case.
protected void tearDown() throws Exception {
Connection con = JDBC2Tests.openDB();
Statement stmt = con.createStatement();
stmt.executeUpdate("DROP TABLE test_a");
stmt.executeUpdate("DROP TABLE test_c");
stmt.close();
JDBC2Tests.closeDB(con);
}
/** /**
* Tests the two forms of createStatement() * Tests the two forms of createStatement()
*/ */
......
...@@ -6,7 +6,7 @@ import java.sql.*; ...@@ -6,7 +6,7 @@ import java.sql.*;
import java.math.BigDecimal; import java.math.BigDecimal;
/** /**
* $Id: JBuilderTest.java,v 1.1 2001/02/13 16:39:05 peter Exp $ * $Id: JBuilderTest.java,v 1.2 2001/09/07 22:17:48 momjian Exp $
* *
* Some simple tests to check that the required components needed for JBuilder * Some simple tests to check that the required components needed for JBuilder
* stay working * stay working
...@@ -18,6 +18,26 @@ public class JBuilderTest extends TestCase { ...@@ -18,6 +18,26 @@ public class JBuilderTest extends TestCase {
super(name); super(name);
} }
// Set up the fixture for this testcase: the tables for this test.
protected void setUp() throws Exception {
Connection con = JDBC2Tests.openDB();
JDBC2Tests.createTable( con, "test_c",
"source text,cost money,imageid int4" );
JDBC2Tests.closeDB(con);
}
// Tear down the fixture for this test case.
protected void tearDown() throws Exception {
Connection con = JDBC2Tests.openDB();
Statement stmt = con.createStatement();
stmt.executeUpdate("DROP TABLE test_c");
stmt.close();
JDBC2Tests.closeDB(con);
}
/** /**
* This tests that Money types work. JDBCExplorer barfs if this fails. * This tests that Money types work. JDBCExplorer barfs if this fails.
*/ */
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment