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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/355633.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python自动化之正则

import re phoneNumRegexre.compile(r\d\d\d-\d\d\d-\d\d\d\d) mophoneNumRegex.search(My number is 415-555-4242.) print(Phone number found: mo.group()) #######利用括号分组############## phoneNumRegexre.compile(r(\d\d\d)-(\d\d\d-\d\d\d\d)) mophoneNumRegex.searc…

mysql递归查询所有上下节点_非递归打印二叉树的所有路径,保存父节点和孩子节点到底有啥差别...

题目解读题目要求输出二叉树的所有路径(字符串形式)&#xff0c;乍一看很简单&#xff0c;不就是二叉树的遍历嘛&#xff01;其实不然&#xff0c;首先&#xff0c;我们用非递归的方式(C)解决这道题(递归在产品代码中是不允许使用的&#xff0c;其次定位 bug 的时候非常困难)。…

发现大量Java原语集合处理

在阅读博客文章5减少Java垃圾收集开销的技巧时 &#xff0c;我想起了一个名为Trove的小型Java收集库&#xff0c;该库“为Java提供了高速的常规和原始收集”。 我对应用Trove允许原始类型的集合而不是要求集合中的元素成为完整的引用对象的能力特别感兴趣。 我在这篇文章中会更…

51nod1244 欧拉函数之和 杜教筛

和上一题差不多&#xff0c;一个是μ*Ie&#xff0c;一个是φ*IId 稍改就得到了这题的代码 &#xff08;我会告诉你我一开始逆元算错了吗&#xff09; 1 #include <bits/stdc.h>2 #define MAX 50000003 #define MOD 10000000074 using namespace std;5 long long a,b,N;6…

java7代码示例_Java中的七种排序方式代码示例

packagebaseJava;/*** title SortMethods.java*authorDonsenChen* Date 2018年5月2日 上午10:16:03* Description*/public classSortMethods {public static voidmain(String[] args) {int[] arr { 3, 7, 9, 1, 4, 8, 2, 6, 5};binarySort(arr);bubbleSort(arr);quickSort(arr…

nginx配置多个server_Nginx基本属性配置详解

. Nginx服务的基本配置1.1 用于调试进程和定位问题的配置项是否以守护进程的方式运行nginx# 默认ondaemon on|off;是否以master/worker方式工作# 默认on&#xff0c;指定了是否以master-worker进程的方式运行&#xff0c;如果设置为off&#xff0c;那么所有的请求将只会由maste…

android-DNS服务找不到

1、重启eclipse 2、重新建立AVD 3、在建立AVD时sd卡数值不要填转载于:https://www.cnblogs.com/shouhutian/p/6838327.html

数据增长率怎么算_20年老股民告诉你5个数据可轻松算出股价是否高估

自从开通自媒体以来&#xff0c;有很多朋友问我该如何正确判断股票的合理价格呢&#xff1f;说得太专业&#xff0c;可能很多新入市的股民朋友看不懂。那有没有一种估值方法通俗易懂呢&#xff1f;说实话&#xff0c;真有点为难我了。我首先想到了最简单的PE估值法&#xff0c;…

与Selenium的集成测试

总览 我已经使用了一段时间&#xff0c;并且遇到了一些似乎可以使生活更轻松的事情。 我以为可以将其作为教程分享&#xff0c;所以我将向您介绍这些部分&#xff1a; 使用Maven设置Web项目&#xff0c;配置Selenium以在CI上作为集成测试运行 研究使用“页面对象”为网站中的…

MFC程序打开文件对话框出错的问题解决

前几天从网上下了个图像分析的mfc小程序&#xff0c;是VC6的 用VC6在本地编译生成都没问题。执行起来弹出一个未处理的错误&#xff0c;程序崩溃退出。 想起来原来遇到过打开文件对话框方面的问题&#xff0c;当时项目时间紧张未能深究。 这次要好好看下这个问题。 详细做法就是…

ad 单点登录 java 访问权限_AD 单点登录以及windows认证详细说明

上篇博客我谈到了一些关于ASP.NET Forms身份认证方面的话题&#xff0c;这次的博客将主要介绍ASP.NET Windows身份认证。Forms身份认证虽然使用广泛&#xff0c;不过&#xff0c;如果是在 Windows Active Directory 的环境中使用ASP.NET&#xff0c; 那么使用Windows身份认证也…

index加载显示servlet数据_[WEB篇]-JavaWeb基础与应用-02-Servlet开发

JavaWeb基础与应用2.Servlet开发Servlet是sun公司提供的一门用于开发动态web资源的技术。Sun公司在其API中提供了一个servlet接口&#xff0c;用户若想用发一个动态web资源(即开发一个Java程序向浏览器输出数据)&#xff0c;需要完成以下2个步骤&#xff1a;编写一个Java类&…

Linux命令之stty

用途说明 stty命令用于显示和修改终端行设置&#xff08;change and print terminal line settings&#xff09;。 常用参数 stty命令不带参数可以打印终端行设置&#xff0c;加上-a参数可以打印得更详细些。 stty size可以显示终端的大小&#xff0c;即行数和列数。 stty命令还…

本机速度文件支持的“纯” Java大数据存储

动机 所有这一切始于意识到我买不起足够大的计算机。 音频处理需要大量的内存。 Audacity是一款出色的免费音频处理器&#xff0c;它使用文件支持的存储系统对其进行管理。 这是解决此类问题的常用方法&#xff0c;在这些问题中&#xff0c;我们存储了大量信息&#xff0c;并希…

element ui后台html_GitHub上10个开源且优秀的后台管理系统UI面板

作者&#xff1a;SevDotwww.jianshu.com/p/3bc7404af887Web 开发中几乎的平台都需要一个后台管理&#xff0c;但是从零开发一套后台控制面板并不容易&#xff0c;幸运的是有很多开源免费的后台控制面板可以给开发者使用&#xff0c;那么有哪些优秀的开源免费的控制面板呢&#…

mysql 唯一记录_mysql选择唯一记录

我有以下查询&#xff1a;select * from members,subscriptionswhere members.MemberID subscriptions.MemberIDand subscriptions.Year 2009and members.ASSCID 15and subscriptions.Untildate between $2009-01-01 and 2009-12-31order by members.Memberlastname会员支付…

JAVA第七次作业

《Java技术》第七次作业 &#xff08;一&#xff09;学习总结 1.写出事件处理模型中的几个关键词&#xff0c;并通过具体代码实例说明你对事件处理模型的理解。 WindowListener&#xff1a;窗体事件&#xff0c;专门处理窗体的事件监听口&#xff0c;窗体的所有变化都可以使用此…

java时间格式转js_使用jquery或java脚本将日期时间转换为rfc3339格式

您的要求似乎微不足道&#xff0c;还有更多吗&#xff1f;这是显而易见的答案&#xff1a;function formatTimestring(s) {var b s.split(/[\\/:]/);return b[2] b[1] b[0] \T\ b[3] b[4] \00\ \Z\}alert(formatTimestring(\08/09/2010:12:00\) //20100908T120000Z);如…

输出以下图案菱形7行_春夏格子图案超流行,三木的一款格子连衣裙,带来田园少女风...

春夏搭配中&#xff0c;增添了华丽格子图案搭配&#xff0c;从经典的格子裙子&#xff0c;到衬衫裙等。根据搭配不同而成为不同风格。所以&#xff0c;这一次&#xff0c;重点介绍格子裙和长衬衫的几种种搭配。格子裙子的春夏搭配推荐LOOK&#xff1a;1 [格子褶皱裙子棕色T恤]的…

asp.net FileUpload上传文件夹并检测所有子文件

1.在FileUpload控件添加一个属性 webkitdirectory""就可以上传文件夹了 <asp:FileUpload ID"FileUpload1" runat"server" webkitdirectory"" />2.检测文件夹下所有子文件 string DirectoryName FileUpload1.PostedFile.FileNam…