博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Unitils集成DBUnit、Spring-单元测试
阅读量:6513 次
发布时间:2019-06-24

本文共 5862 字,大约阅读时间需要 19 分钟。

 

  Unitils集成DBUnit、Spring-单元测试

  1、maven-pom文件中引入相关jar包  

org.unitils
unitils-dbunit
3.4.2
org.unitils
unitils-io
3.4.2
org.unitils
unitils-database
3.4.2
org.unitils
unitils-spring
3.4.2

  以上Unitils集成dbunit、Spring所必须jar包,工程文件是通过maven构建的,所以都是maven的目录结构。

  2、引入unitils的配置文件unitils.properties,这个配置文件可以用unitils-core的jar包中copy出来,然后进行自定义配置,如下:

#启用unitils所需模块unitils.modules=database,dbunit,spring#自定义扩展模块,详见实例源码#unitils.module.dbunit.className=org.unitils.dbunit.DbUnitModuleunitils.module.dbunit.className=com.candle.util.MySqlDbUnitModule#配置数据库连接database.driverClassName=com.mysql.jdbc.Driverdatabase.url=jdbc:mysql://127.0.0.1:3306/test?autoReconnect=true&useUnicode=true&characterEncoding=utf-8database.userName=rootdatabase.password=123qwe#配置为数据库名称database.schemaNames=test#配置数据库方言database.dialect=mysql#配置数据库维护策略.请注意下面这段描述 # If set to true, the DBMaintainer will be used to update the unit test database schema. This is done once for each # test run, when creating the DataSource that provides access to the unit test database.updateDataBaseSchema.enabled=false#配置数据库表创建策略,是否自动建表以及建表sql脚本存放目录#dbMaintainer.autoCreateExecutedScriptsTable=false#dbMaintainer.script.locations=D:\workspace\unit-demo\src\test\java\com\candle\dao#数据集加载策略#CleanInsertLoadStrategy:先删除dateSet中有关表的数据,然后再插入数据 #InsertLoadStrategy:只插入数据 #RefreshLoadStrategy:有同样key的数据更新,没有的插入 #UpdateLoadStrategy:有同样key的数据更新,没有的不做任何操作 DbUnitModule.DataSet.loadStrategy.default=org.unitils.dbunit.datasetloadstrategy.impl.CleanInsertLoadStrategy#配置数据集工厂DbUnitModule.DataSet.factory.default=org.unitils.dbunit.datasetfactory.impl.MultiSchemaXmlDataSetFactoryDbUnitModule.ExpectedDataSet.factory.default=org.unitils.dbunit.datasetfactory.impl.MultiSchemaXmlDataSetFactory#配置事务策略 commit、rollback 和disabled;或者在代码的方法上标记@Transactional(value=TransactionMode.ROLLBACK)#commit 是单元测试方法过后提交事务#rollback 是回滚事务#disabled 是没有事务,默认情况下,事务管理是disabledDatabaseModule.Transactional.value.default=disabled#配置数据集结构模式XSD生成路径,可以自定义目录,但不能为空dataSetStructureGenerator.xsd.dirName=/dbMaintainer.generateDataSetStructure.enabled=true

  自定义配置文件有两个,分别是unitils.properties和unitils-local.properties,但通常我们只需要配置unitils.properties即可,这个配置文件默认是放在工程的根目录下,我这里的测试

根目录是/src/test/resources/下。因为unitils默认是这样去读取配置文件的,所以不建议移动到其他目目录,不然可能需要更改读取配置文件的代码了。

  3、写一个mysql数据库配置的类,用于解决dbunit中存在的bug,在上一篇博客中有讲到,代码如下  

package com.candle.util;import org.dbunit.database.DatabaseConfig;import org.dbunit.ext.mysql.MySqlDataTypeFactory;import org.dbunit.ext.mysql.MySqlMetadataHandler;import org.unitils.dbunit.DbUnitModule;import org.unitils.dbunit.util.DbUnitDatabaseConnection;public class MySqlDbUnitModule extends DbUnitModule {    @Override    public DbUnitDatabaseConnection getDbUnitDatabaseConnection(            final String schemaName) {        DbUnitDatabaseConnection result = dbUnitDatabaseConnections                .get(schemaName);        if (null != result) {            return result;        }        result = super.getDbUnitDatabaseConnection(schemaName);        result.getConfig().setProperty(                DatabaseConfig.PROPERTY_DATATYPE_FACTORY,                new MySqlDataTypeFactory());        result.getConfig().setProperty(                DatabaseConfig.PROPERTY_METADATA_HANDLER,                new MySqlMetadataHandler());        return result;    }}

  加如上类之后,再去看unitils.properties中  

#自定义扩展模块,详见实例源码#unitils.module.dbunit.className=org.unitils.dbunit.DbUnitModuleunitils.module.dbunit.className=com.candle.util.MySqlDbUnitModule          如上就制定到自定义的类com.candle.util.MySqlDbUnitModule,解决dbunit中可能存在的bug 4、准备测试数据 @DataSet和@ExpectedDataSet 这里都用xml来存放数据,如果要用excel,需要重写excel获取数据的相关代码 xml存放路径如下:src/test/resources/dataSetXml/,目录下包括@DataSet数据(login.xml)和@ExpectedDataSet数据login_expect.xml 5、测试代码
package com.candle.dao;import static org.junit.Assert.*;import org.junit.Test;import org.unitils.UnitilsJUnit4;import org.unitils.database.annotations.Transactional;import org.unitils.database.util.TransactionMode;import org.unitils.dbunit.annotation.DataSet;import org.unitils.dbunit.annotation.ExpectedDataSet;import org.unitils.reflectionassert.ReflectionAssert;import org.unitils.spring.annotation.SpringApplicationContext;import org.unitils.spring.annotation.SpringBean;import com.candle.model.LoginDO;@SpringApplicationContext({
"applicationContext-test.xml"})public class LoginDAOTest5 extends UnitilsJUnit4{ //Spring容器中加载Id为"userService"的Bean @SpringBean("loginDAO") private LoginDAO loginDAO ; @Test @ExpectedDataSet("/dataSetXml/login_expect.xml") public void testSaveLogin() { LoginDO loginDo = new LoginDO(); loginDo.setId(2); loginDo.setName("thomas"); loginDo.setPasswd("123qwe"); loginDAO.saveLogin(loginDo); } @Test @DataSet("/dataSetXml/login.xml") //@Transactional(value=TransactionMode.ROLLBACK) public void testFindById() { LoginDO loginDo = loginDAO.findById(1) ; ReflectionAssert.assertPropertyLenientEquals("name","candle",loginDo) ; assertNotNull("空置", loginDo); assertEquals("candle",loginDo.getName()) ; } }

  其中,关于unitils集成spring,就是通过集成UnitilsJUnit4类引入spring的配置文件,即可完成Spring的bean之类的重用~

  6、回滚问题

  通过以上配置,包括事务配置,通过测试发现,unitils的事务是集成自Spring的,所以如果当测试类中集成了Spring的applicationContext配置文件,则unitils中的事务配置无效,这里测试过回滚事务,

  DatabaseModule.Transactional.value.default=rollback,在测试中引用Spring的配置时,此回滚无效,如果不引用Spring的配置,则可以生效~

  此问题有待研究~

  

 

 

转载地址:http://grifo.baihongyu.com/

你可能感兴趣的文章
安防众筹不止于卖产品 思维拓展刺激消费
查看>>
艾特网能获2016APCA用户满意品牌大奖
查看>>
《CCNP TSHOOT 300-135学习指南》——第2章 结构化故障检测与排除进程
查看>>
《Java EE 7精粹》—— 2.5 非阻塞I/O
查看>>
《R数据可视化手册》——1.1 安装包
查看>>
spring-aop
查看>>
android RecycleView Adapter简单封装
查看>>
Dart的数据库操作
查看>>
Codeforces 591 B Rebranding【Codeforces Round #327 (Div. 2)】
查看>>
命名难,难于上青天
查看>>
APUE读书笔记-05标准输入输出库(7)
查看>>
23 第一周作业
查看>>
DNS解析偶尔延迟
查看>>
iOS打电话,发短信,发邮件,打开网址
查看>>
06-验证码-基本功能实现
查看>>
Java数据结构与算法(六) 希尔排序
查看>>
canvas学习笔记
查看>>
elasticsearch安装步骤
查看>>
PHP获取Cookie模拟登录CURL(转)
查看>>
PHP-权限控制类(转)
查看>>