在进行本地单元测试的时候,有时候需要对数据库进行操作,但数据库环境又很难维护,即使费老大力气完成了本地数据库数据的构造,由于一些其他的变动或者别人的改动也会导致testCase跑不通,这就造成了辛辛苦苦构造数据库写的testCase就一次有效,这对于之后的回归测试以及代码维护都是一个麻烦事,因此经研究和试用后发现运用Spring内存数据库(Embedded database)可以很方便的解决这种麻烦。
Embedded database 是Spring提供的一套虚拟db,利用它可以很方便的进行单元测试
1,gradle中引入如下依赖
testCompile 'com.h2database:h2:1.4.192'
2,代码方式创建 embedded database(init.sql 是创建数据库的脚本,新增的表记得添加脚本,@Bean 中name 的值是Spring.xml中配置的DataSource的bean id)