目的搞清楚了就最容易做事了。嘿嘿。如果不知DBUnit是用来做什么的,就像个无头苍蝇,晃了半天都不清楚在看些什么。
DBUnit的主要功能是可以为你的数据库测试提供稳定及一致的数据。DBUnit通过预先在XML文件设置数据值、使用Sql查询另外的表格为测试提供数据等等方式来达到这个目的,而通常我们只需要使用XML文件预置数据的方法即可。
使用DBUnit来写单元测试至少有两个方法,一是直接继承
DBUnit的主要功能是可以为你的数据库测试提供稳定及一致的数据。DBUnit通过预先在XML文件设置数据值、使用Sql查询另外的表格为测试提供数据等等方式来达到这个目的,而通常我们只需要使用XML文件预置数据的方法即可。
使用DBUnit来写单元测试至少有两个方法,一是直接继承
DatabaseTestCase,实现该类的两个方法。DBUnit在测试运行中会自动更新和保持数据库的信息一致和完整。二是像往常那样继承一般的TestCase类,在SetUp方法中自已操作数据库,使之达到平衡。如:
protected void setUp() throws Exception
{
IDatabaseConnection connection =
new DatabaseDataSourceConnection(new InitialContext(),
"java:/DefaultDS");
IDataSet dataSet = new FlatXmlDataSet(
this.getClass().getResource(
"/junitbook/database/data.xml"));
try
{
DatabaseOperation.CLEAN_INSERT.execute(connection,
dataSet);//先删除数据库原有的数据再把XML文件里的数据保存到数据库,
达到每次测试数据都相同的目的。
}
finally
{
connection.close();
}
}
PS:DBUnit应该尽量运用在集成测试下,如果是一般的业务逻辑操作测试,尽可能使用MockObject来写测试代码。