用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");
(来源www.iocblog.net)
        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来写测试代码。



文章整理:iocblog
版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。