除了前面那兩個方法外,我們還重載了 getSetUpOperation 和 getTearDownOperation 方法:DatabaseOperation.REFRESH 告訴DBUnit在測試開始前比較數(shù)據(jù)庫和配置文件,如果發(fā)現(xiàn)測試數(shù)據(jù)不存或不一致在則插入或更新***。DatabaseOperation.NONE表示什么也不做。
這個CASE應該可以運行的很好,但是如果我們把 getTearDownOperation改成:
@Override
protected DatabaseOperation getTearDownOperation() throws Exception
{
return DatabaseOperation.DELETE_ALL;
}
會發(fā)生java.sql.SQLException: Closed Connection異常。這是為什么呢?問題出在DatabaseTestCase中。
***參數(shù)含義
DatabaseOperation.CLEAN_INSERT; 先刪除表中所有,再插入準備的數(shù)據(jù)
DatabaseOperation.REFRESH; 使用準備數(shù)據(jù)更新表,存在則update,不存在則insert
DatabaseOperation.DELETE; 只刪除準備的數(shù)據(jù)
DatabaseOperation.DELETE_ALL 清除所有記錄
DatabaseOperation.NONE; 啥都不做
java.sql.SQLException: Closed Connection異常
來看一下DatabaseTestCase的一個關(guān)鍵成員變量tester和有關(guān)的一些方法:
public abstract class DatabaseTestCase extends TestCase
{
......
private IDatabaseTester tester;
......
protected IDatabaseTester getDatabaseTester() throws Exception {
if (this.tester == null) {
this.tester = newDatabaseTester();
}
return this.tester;
}
......
protected IDatabaseTester newDatabaseTester() throws Exception{
logger.debug("newDatabaseTester()- start");
// 重載的 getConnection 方法,在 IDatabaseTester 里有一個同名方法。
// 注意區(qū)分。
final IDatabaseConnection connection = getConnection();
final IDatabaseTester tester
= new DefaultDatabaseTester(connection);
return tester;
}
......
protected void setUp() throws Exception
{
logger.debug("setUp()- start");
super.setUp();
final IDatabaseTester databaseTester = getDatabaseTester();
assertNotNull("DatabaseTesteris not set", databaseTester);
databaseTester.setSetUpOperation(getSetUpOperation());
databaseTester.setDataSet(getDataSet());
databaseTester.onSetup();
}
......
}
可見 DatabaseTestCase 內(nèi)部有一個 IDatabaseTester 接口的實例(tester),實際上所有的測試工作是由它完成的。而DatabaseTestCase的newDatabaseTester方法在生成這個實例的時候用的是DefaultDatabaseTester。傳入一個由重載的getConnection方法返回的IDatabaseConnection實例。
DefaultDatabaseTester記錄了這個連接實例后,提供了一個同名的getConnection()方法(不是DatabaseTestCase中被重載的那個getConnection),用來返回它:
public class DefaultDatabaseTester extends AbstractDatabaseTester
{
final IDatabaseConnection connection;
public DefaultDatabaseTester(final IDatabaseConnection connection){
this.connection= connection;
}
public IDatabaseConnection getConnection() throws Exception {
return this.connection;
}
}