针对整合的Dao层与Service层,在做spring与通用Mapper和分页插件相关测试时比较麻烦。如果只用JUnit测试,需要每次Test方法里初始化一下applicationContext,效率比较低下。并且还要进行强制类型转换的造型操作。使用Spring测试套件,测试用例类中的属性会被自动填充Spring容器的对应Bean,直接使用@Autowired注入使用即可!
本次测试目的是看看通用Mapper插件具体如何整合传统SSM项目。
在maven的pom.xml中加入以下配置,其他spring相关配置见后面的附录。
一、导入依赖坐标
<dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> <scope>test</scope> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>4.3.25.RELEASE</version> </dependency>
二、定义一个测试基类
这是利用了Java语言的继承性,可以简化未来具体用到的测试类,不用写重复的注解部分的代码。
import org.junit.runner.RunWith; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; /** * 配置spring和junit整合,junit启动时加载springIOC容器 spring-test,junit */ @RunWith(SpringJUnit4ClassRunner.class) // 告诉junit spring配置文件的位置 @ContextConfiguration({ "classpath:spring/spring-redis.xml","classpath:spring/spring-dao.xml", "classpath:spring/spring-service.xml" }) public class BaseTest { }
三、编写具体的测试类,继承刚刚的测试基类:
通用Mapper插件是对mybatis框架在单表CRUD操作时支持性很好。此处的selectAll()和select(null)方法的查询效果是一样的,都是查询所有。
public class SpringTkMapperTest extends BaseJunit4Test { @Autowired UserMapper userMapper; @Test public void testUserMapper() { //List<User> userList = userMapper.selectAll(); List<User> userList = userMapper.select(null); System.out.println(userList); } }
附录:
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:context="http://www.springframework.org/schema/context" xmlns:p="http://www.springframework.org/schema/p" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util.xsd"> <!-- 加载配置文件,可以使用占位符替换功能 --> <context:property-placeholder location="classpath:properties/*.properties" ignore-unresolvable="true" /> <!-- 定义dataSource数据源 --> <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" destroy-method="close"> <!-- 数据库驱动 --> <property name="driverClassName" value="${jdbc.driver}" /> <!-- 相应驱动的jdbcUrl --> <property name="url" value="${jdbc.url}" /> <!-- 数据库的用户名 --> <property name="username" value="${jdbc.username}" /> <!-- 数据库的密码 --> <property name="password" value="${jdbc.password}" /> <!-- 配置初始化大小、最小、最大 --> <property name="initialSize" value="5" /> <property name="minIdle" value="5" /> <property name="maxActive" value="10" /> <!-- 配置从连接池获取连接等待超时的时间,单位是毫秒 --> <property name="maxWait" value="10000" /> <!-- 配置间隔多久启动一次DestroyThread,对连接池内的连接才进行一次检测,单位是毫秒。 检测时:1.如果连接空闲并且超过minIdle以外的连接,如果空闲时间超过minEvictableIdleTimeMillis设置的值则直接物理关闭。 2.在minIdle以内的不处理。 --> <property name="timeBetweenEvictionRunsMillis" value="600000" /> <!-- 配置一个连接在池中最大空闲时间,单位是毫秒 --> <property name="minEvictableIdleTimeMillis" value="300000" /> <!-- 设置从连接池获取连接时是否检查连接有效性,true时,每次都检查;false时,不检查 --> <property name="testOnBorrow" value="false" /> <!-- 设置往连接池归还连接时是否检查连接有效性,true时,每次都检查;false时,不检查 --> <property name="testOnReturn" value="false" /> <!-- 设置从连接池获取连接时是否检查连接有效性, true时,如果连接空闲时间超过minEvictableIdleTimeMillis进行检查,否则不检查; false时,不检查 --> <property name="testWhileIdle" value="true" /> </bean> <!-- 让spring管理sqlSessionFactory 使用mybatis和spring整合包中的 --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!-- 数据库连接池 --> <property name="dataSource" ref="dataSource" /> <!-- 加载mybatis的全局配置文件 --> <property name="configLocation" value="classpath:mybatis/mybatis-config.xml" /> <!-- 实体类别名包 --> <property name="typeAliasesPackage" value="cn.itcast.usermanage.pojo"/> <!-- 配置mapper.xml文件 --> <!-- <property name="mapperLocations" value="classpath*:mybatis/mappers/*Mapper.xml"/> --> <property name="plugins"> <array> <bean class="com.github.pagehelper.PageInterceptor"> <property name="properties"> <value> helperDialect=mysql reasonable=true rowBoundsWithCount=true </value> </property> </bean> </array> </property> </bean> <!-- 配置扫描接口包,加载通用mapper代理对象 --> <bean class="tk.mybatis.spring.mapper.MapperScannerConfigurer"> <!-- 扫描多个包地址 --> <property name="basePackage" value="cn.itcast.usermanage.mapper" /> </bean> </beans>
<!-- 集中定义依赖版本号,参考了SpringBboot启动器的版本 --> <properties> <junit.version>4.12</junit.version> <slf4j.version>1.7.28</slf4j.version> <spring.version>4.3.25.RELEASE</spring.version> <mybatis.version>3.4.6</mybatis.version> <mybatis.spring.version>1.3.2</mybatis.spring.version> <mybatis.paginator.version>1.2.17</mybatis.paginator.version> <mapper.version>4.1.5</mapper.version> <pagehelper.version>5.1.10</pagehelper.version> <jsqlparser.version>2.0</jsqlparser.version> <mysql.version>5.1.47</mysql.version> <druid.version>1.1.15</druid.version> <jackson.version>2.9.9.3</jackson.version> <jstl.version>1.2</jstl.version> <servlet-api.version>3.1.0</servlet-api.version> <jsp-api.version>2.2</jsp-api.version> <httpclient.version>4.5.10</httpclient.version> <joda-time.version>2.9.9</joda-time.version> <commons-lang3.version>3.9</commons-lang3.version> <commons-io.version>2.5</commons-io.version> <commons-net.version>3.6</commons-net.version> <commons-fileupload.version>1.4</commons-fileupload.version> <jedis.version>3.1.0</jedis.version> <solrj.version>7.7.2</solrj.version> </properties>
=======================================================
参考资料:https://www.cnblogs.com/gkaigk1987/articles/5367569.html