SpringBoot DBUnit 单元测试(小结)

网友投稿 519 2023-01-22


SpringBoot DBUnit 单元测试(小结)

DBunit 是一种扩展于JUnit的数据库驱动测试框架,它使数据库在测试过程之间处于一种已知状态,如果一个测试用例对数据库造成了破坏性影响,它可以帮助避免造成后面的测试失败或者给出错误结果。

DBunit通过维护真实数据库与数据集(IDataSet)之间的关系来发现与暴露测试过程中的问题。IDataSet 代表一个或多个表的数据。此处IDataSet可以自建,可以由数据库导出,并以多种方式体现,xml文件、XLS文件和数据库查询数据等。

基于DBUnit 的测试的主要接口是IDataSet,可以将数据库模式的全部内容表示为单个IDataSet 实例。这些表本身由Itable 实例来表示。

1. pom文件配置

org.springframework.boot

spring-boot-starthttp://er-test

com.github.springtestdbunit

spring-test-dbunit

1.3.0

test

org.dbunit

dbunit

2.5.3

2. 由于spring-test-dbunit 的注解配置,导致 mockito 中的 @MockBean 失效,需要将 MockitoTestExecutionListener 和 DbUnitTestExecutionListener 配置到 @TestExecutionListeners 中

@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 中允在空值的配置

package com.test;

import com.github.springtestdbunit.beanhttp://.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;

}

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:使用google.kaptcha来生成图片验证码的实现方法
下一篇:搭建研发管理平台(企业研发平台)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~