技术开发 频道

Unitils——简化测试

【IT168 技术文章】

  Unitils是一个简化测试开发,提高测试维护性的一个开源项目,这里有开发者做的一个presentation.目前提供的功能为:

  General testing utilities :提供一些测试的辅助方法,主要是通过反射进行数据验证。
  Database testing utilities:

  自动维护测试数据库,并且可以自动关闭测试数据库的constranits
  提供类似于dbdeploy和rails migration的数据库版本控制
  简化单元测试数据库connection的获取
  简化dbunit维护测试数据的操作
  Hibernate支持
  单元测试事务的管理,可以选择有Unitils管理,还是spring管理
  Mock object utilities:简化Mock ojbect的creation,injection,和match
  Spring integration:可以方便的在单元测试中获取spring管理的bean。
  以前做数据库测试的时候,最麻烦的就是测试数据集的管理。unitils提供了非常好的数据库测试支持,下面我们看一个简单的例子:

  需要测试的类Java代码
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) {  
    ...  
  }  

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) {
    ...
  }
}
  测试类Java代码
@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());  
   }  

@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());
   }
}
  测试数据文件。Unitils默认按testClassName.xml到相同目录下找测试文件,然后自动装载,装载前先自动清空测试文件中包含的table,然后再转载这些table的数据。Xml代码
<?xml version='1.0' encoding='UTF-8'?> 
<dataset>           
    <user id="1" name="foo" />       
</dataset> 

<?xml version='1.0' encoding='UTF-8'?>
<dataset>        
    <user id="1" name="foo" />    
</dataset>
  其他的设置主要是unitils在配置文件unitils.properties(http://www.unitils.org/unitils.properties)中修改数据库的配置,并且放到classpath下面。依赖jar可以在unitils网站上看到。
  这样一个UserDAO的测试就做完了。unitils可以为每个类(或者方法,建议是类)指定测试数据文件,在测试开始的时候自动装载相关表格的数据。这是我最感兴趣的功能之一,简化的测试数据的管理。同时unitils的提供的mock支持可以显著减少使用mock时create mock的代码

Java代码
@Mock 
private UserDao mockUserDao; 

@Mock
private UserDao mockUserDao; 
unitils项目还提供了一些其他功能:

多数据库测试Xml代码
<?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> 

<?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>
  简介中提到的类似于dbdeploy和rails migration的DBMaintainer,可以通过sql文件维护测试数据库版本。这个也是比较有用的功能,感兴趣的可以去unitils网站看文档。
  一个Unit Test非常好的实践的guide. http://www.unitils.org/guidelines.htm可以很容易扩展unitils,实现自己的modules。

0
相关文章