我在项目中使用Spring和Hibernate的组合,并希望测试DAO方法,如Save
和Delete
方法。
daoFoundation是一个通过hibernateSession创建的包装类。
@Override
public String createSubject(Subject subject) {
String subjectId = (String) daoFoundation.save(subject);
return subjectId;
}
这是我在JUnit Runs中用SpringJunit4ClassRunner写的 我在SetupMethod中创建了主题对象。
@Test
public void createSubjectTest(){
subjectDao.createSubject(subject);
assertNotNull(hassSubjectSelection.getId());
}
这是否足够,还是我需要在我的测试类中另外编写任何内容?
答案 0 :(得分:7)
最简单的方法是导入Spring应用程序上下文,在要测试的DAO中自动装配,然后将测试方法或整个类标记为@Transactional
。这将创建一个Hibernate会话,运行您的测试,然后自动回滚事务,这样您就不会通过测试影响数据库状态。
看看如何使用Spring here运行单元测试。您可以使用@ContextConfiguration
注释使Spring创建整个应用程序上下文。因此,如果使用名为database-servlet.xml
的XML文件创建数据库,则需要注释
@ContextConfiguration(locations={"classpath:/database-servlet.xml"})
public class Test()
您可以使用注释@RunWith(SpringJUnit4ClassRunner.class)
将Spring TestContext Framework的功能与单元测试结合使用。这允许你做一些事情,比如声明应抛出的预期异常,运行定时测试,重复测试运行X次以及一堆其他很酷的东西。
基本上为了使其正常工作,您的测试类应该类似于以下内容:
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={YOUR APP CONTEXT FILES HERE AS A COMMA SEPARATED LIST})
public class Test(){
@Autowired
private YourDAO yourDAO;
@Test
@Transactional
public void testSave(){
//Test save method here. Any database changes made here will be
//automatically rolled back when the test finishes.
}
让我知道这是否有效。
答案 1 :(得分:1)
测试你的dao层的最好方法是使用spring jdbctemplate将数据写入数据库测试你的get和delete方法。然后在@after中删除你写的记录。然后使用hibernate写入数据库并使用jdbctemplate读取它们。然后删除您的测试行。你正在做的就是测试hibernate的缓存。