@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
文章来源于领测软件测试网 https://www.ltesting.net/