dbunit测试dao_用于数据库测试的DBUnit,Spring和注释

dbunit测试dao

如果您曾经尝试用Java编写数据库测试,则可能会遇到DBUnit 。 DBUnit允许您设置和拆除数据库,以便它包含可针对其编写测试的一致行。

通常,您可以通过编写一个简单的XML文档来指定要DBUnit插入的行,例如:

<?xml version="1.0" encoding="UTF-8"?>
<dataset>
 <Person id="0" title="Mr" firstName="Dave" lastName="Smith"/>
 <Person id="1" title="Mrs" firstName="Jane" lastName="Doe"/>
</dataset>

您也可以使用相同格式的XML文件来断言数据库包含特定的行。

DBUnit在使用内存数据库时效果特别好,如果使用Spring,则设置起来非常简单。 是一篇很好的文章,描述了如何入门。

直接使用DBUnit是可以的,但是一段时间后,您会发现有多少测试遵循相同的数据库设置模式,然后测试结果。 为了减少重复,您可以使用spring-test-dbunit项目 。 该项目托管在GitHub上,并提供了一组新的批注,可以将其添加到您的测试方法中。 1.0.0版刚刚发布,现在可以在Maven中央存储库中使用:

<dependency>
  <groupId>com.github.springtestdbunit</groupId>
  <artifactId>spring-test-dbunit</artifactId>
  <version>1.0.0</version>
  <scope>test</scope>
</dependency>

安装后,可以在测试中使用三个新的注释: @DatabaseSetup@DatabaseTearDown@ExpectedDatabase 。 这三种都可以在测试类上使用,也可以在单独的测试方法上使用。

@DatabaseSetup@DatabaseTearDown批注用于在测试运行之前或测试完成之后将数据库置于一致状态。 您指定要用作注释值的数据集,例如:

@Test
@DatabaseSetup("sampleData.xml")
public void testFind() throws Exception {
  // test code
}

测试完成后, @ ExpectedDatabase批注用于验证数据库的状态。 与前面的注释一样,您必须指定要使用的数据集。

@Test
@DatabaseSetup("sampleData.xml")
@ExpectedDatabase("expectedData.xml")
public void testRemove() throws Exception {
  // test code
}

您可以在两种不同的模式下使用@ExpectedDatabase ,具体取决于验证的严格程度(有关详细信息,请参见JavaDocs )。

对于要处理的注释,您需要确保测试使用的是DbUnitTestExecutionListener。 有关完整的详细信息,请参见项目自述文件 。 如果您想了解更多信息,可以在GitHub上找到一个示例项目,在此处获得一些入门指南

参考:来自Phil Webb博客博客的JCG合作伙伴 Phillip Webb 使用DBUnit,Spring和Annotations进行数据库测试


翻译自: https://www.javacodegeeks.com/2012/04/dbunit-spring-and-annotations-for.html

dbunit测试dao

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值