用DBUnit写单元测试

目的搞清楚了就最容易做事了。嘿嘿。如果不知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来写测试代码。


你可能感兴趣的:(sql,xml,单元测试)