使用Junit测试Hibernate DAO

时间:2014-05-05 03:17:24

标签: java spring hibernate junit

我在项目中使用Spring和Hibernate的组合,并希望测试DAO方法,如SaveDelete方法。

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());
}

这是否足够,还是我需要在我的测试类中另外编写任何内容?

2 个答案:

答案 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的缓存。