论坛首页 综合技术论坛

Unitils——简化测试

浏览 5317 次
精华帖 (0) :: 良好帖 (15) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2008-01-28  
/**
*作者:andyao,email:andyaoy@gmail.com
*http://andyao.iteye.com/blog/160004
*/ 

Unitils(http://www.unitils.org/summary.html)是一个简化测试开发,提高测试维护性的一个开源项目,这里有开发者做的一个presentation(http://www.parleys.com/display/PARLEYS/Unitils)。目前提供的功能为:

  1. General testing utilities :提供一些测试的辅助方法,主要是通过反射进行数据验证。
  2. Database testing utilities:
    • 自动维护测试数据库,并且可以自动关闭测试数据库的constranits
    • 提供类似于dbdeploy和rails migration的数据库版本控制
    • 简化单元测试数据库connection的获取
    • 简化dbunit维护测试数据的操作
    • Hibernate支持
    • 单元测试事务的管理,可以选择有Unitils管理,还是spring管理
  3. Mock object utilities:简化Mock ojbect的creation,injection,和match
  4. Spring integration:可以方便的在单元测试中获取spring管理的bean。

以前做数据库测试的时候,最麻烦的就是测试数据集的管理。unitils提供了非常好的数据库测试支持,下面我们看一个简单的例子:

  1. 需要测试的类
    public class User {
     private int  id;
     private String name;
     //set get略
    }
    
    //任何实现都可以,jdbc,hibernate,ibatis等等
    public class UserDAO {
      public void save(User user) {  
        ...
      }     
       
      public User get(int id) {
        ...
      }
    }
     
  2. 测试类
    @SpringApplicationContext({"spring-config.xml"})
    @DataSet
    public class UserDAOTest extends UnitilsJUnit4 {
       @SpringBeanByType
       UserDao userDao;    
    
      @Test
      public void testGet() {
         User user = userDao.get(1);
         assertEquals("foo", user.getName());   
      }
    
      @Test
      public void testSave() {
          User user = new User();
          user.setName("bar"); 
          userDao.save(user);
          assertNotNull(user.getId());
       }
    }
     
  3. 测试数据文件。Unitils默认按testClassName.xml到相同目录下找测试文件,然后自动装载,装载前先自动清空测试文件中包含的table,然后再转载这些table的数据。
    <?xml version='1.0' encoding='UTF-8'?>
    <dataset>         
        <user id="1" name="foo" />     
    </dataset>
     
  4. 其他的设置主要是unitils在配置文件unitils.properties(http://www.unitils.org/unitils.properties)中修改数据库的配置,并且放到classpath下面。依赖jar可以在unitils网站上看到。

这样一个UserDAO的测试就做完了。unitils可以为每个类(或者方法,建议是类)指定测试数据文件,在测试开始的时候自动装载相关表格的数据。这是我最感兴趣的功能之一,简化的测试数据的管理。同时unitils的提供的mock支持可以显著减少使用mock时create mock的代码

@Mock
private UserDao mockUserDao;
  

unitils项目还提供了一些其他功能:

  1. 多数据库测试
    <?xml version='1.0' encoding='UTF-8'?>
    <dataset xmlns="SCHEMA_A" xmlns:b="SCHEMA_B">
        <user id="1" userName="jack" />    
        <b:role id="1" roleName="admin" />
    </dataset>
     
  2. 简介中提到的类似于dbdeploy和rails migration的DBMaintainer,可以通过sql文件维护测试数据库版本。这个也是比较有用的功能,感兴趣的可以去unitils网站看文档。
  3. 一个Unit Test最佳实践的guide. http://www.unitils.org/guidelines.htm
  4. 可以很容易扩展unitils,实现自己的modules。
其他的还有很多有用的功能没有介绍,大家可以查看官方文档。

 

 

 

   发表时间:2008-01-29  
Unitils是一个好东西啊,看一小会官方的例子.
但基本上不会去用这一个Unitils,确切地说与jdk1.5以上的jdk版本还处于绝缘状态
0 请登录后投票
论坛首页 综合技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics