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。