Spring Test+JUnit4整合使用测试ZZJ_淘淘商城项目:day01(RESTful Web Service)

针对整合的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