dbunit 是一种扩展于junit的数据库驱动测试框架,它使数据库在测试过程之间处于一种已知状态,如果一个测试用例对数据库造成了破坏性影响,它可以帮助避免造成后面的测试失败或者给出错误结果。
dbunit通过维护真实数据库与数据集(idataset)之间的关系来发现与暴露测试过程中的问题。idataset 代表一个或多个表的数据。此处idataset可以自建,可以由数据库导出,并以多种方式体现,xml文件、xls文件和数据库查询数据等。
基于dbunit 的测试的主要接口是idataset,可以将数据库模式的全部内容表示为单个idataset 实例。这些表本身由itable 实例来表示。
1. pom文件配置
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
<dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-test</artifactid> </dependency> <dependency> <groupid>com.github.springtestdbunit</groupid> <artifactid>spring-test-dbunit</artifactid> <version> 1.3 . 0 </version> <scope>test</scope> </dependency> <dependency> <groupid>org.dbunit</groupid> <artifactid>dbunit</artifactid> <version> 2.5 . 3 </version> </dependency> |
2. 由于spring-test-dbunit 的注解配置,导致 mockito 中的 @mockbean 失效,需要将 mockitotestexecutionlistener 和 dbunittestexecutionlistener 配置到 @testexecutionlisteners 中
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
@runwith (springrunner. class ) @springboottest (webenvironment = springboottest.webenvironment.random_port) @autoconfiguremockmvc @transactional @transactionconfiguration (transactionmanager = "transactionmanager" , defaultrollback = true ) @testexecutionlisteners ({ dependencyinjectiontestexecutionlistener. class , dirtiescontexttestexecutionlistener. class , transactionaltestexecutionlistener. class , mockitotestexecutionlistener. class , dbunittestexecutionlistener. class }) @databasesetup ( "/test-data.xml" ) public class orderinfocontrollertest { } |
3. dbunit 的数据文件 xml 中允在空值的配置
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
package com.test; import com.github.springtestdbunit.bean.databaseconfigbean; import com.github.springtestdbunit.bean.databasedatasourceconnectionfactorybean; import javax.sql.datasource; import org.slf4j.logger; import org.slf4j.loggerfactory; import org.springframework.context.annotation.bean; import org.springframework.context.annotation.configuration; /** * * @author walli */ @configuration public class dbunitconfiguration { private static final logger logger = loggerfactory.getlogger(dbunitconfiguration. class ); @bean public databaseconfigbean dbunitdatabaseconfig() { databaseconfigbean bean = new databaseconfigbean(); bean.setallowemptyfields( true ); return bean; } @bean public databasedatasourceconnectionfactorybean dbunitdatabaseconnection( databaseconfigbean dbunitdatabaseconfig, datasource datasource) { databasedatasourceconnectionfactorybean bean = new databasedatasourceconnectionfactorybean(datasource); bean.setdatabaseconfig(dbunitdatabaseconfig); return bean; } } |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/zxcvqwer19900720/article/details/80106758