单元测试模板

1 准备工作
1.1 applicationContext.xml
<?xml version="1.0" encoding="UTF-8"?>

    <!-- 扫描service包下所有使用注解的类型 -->
    <context:component-scan base-package="www.test.baidu.service"/>

    <util:properties
            id="jdbcProperty" location="classpath:jdbc.properties">
    </util:properties>
    <!--<util:properties id="jdbcProperty" location="WEB-INF/classes/jdbc.properties">-->
    <!--</util:properties>-->

    <!-- 数据源 -->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="driverClass" value="#{jdbcProperty['jdbc.driver']}"/>
        <property name="jdbcUrl" value="#{jdbcProperty['jdbc.url']}"/>
        <property name="user" value="#{jdbcProperty['jdbc.username']}"/>
        <property name="password" value="#{jdbcProperty['jdbc.password']}"/>
        <property name="maxPoolSize" value="#{jdbcProperty['c3p0.maxPoolSize']}"/>
        <property name="minPoolSize" value="#{jdbcProperty['c3p0.minPoolSize']}"/>
        <property name="autoCommitOnClose" value="#{jdbcProperty['c3p0.autoCommitOnClose']}"/>
        <property name="checkoutTimeout" value="#{jdbcProperty['c3p0.checkoutTimeout']}"/>
        <property name="acquireRetryAttempts" value="#{jdbcProperty['c3p0.acquireRetryAttempts']}"/>
    </bean>

    <!-- 配置SqlSessionFactory对象 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <!-- 注入数据库连接池 -->
        <property name="dataSource" ref="dataSource"/>
        <!-- 扫描model包 使用别名 在pojo.xml中可以不使用全称 -->
        <property name="typeAliasesPackage" value="www.longshine.baidu.dao"/>
        <!-- 扫描sql配置文件:mapper需要的xml文件 -->
        <!--  <property name="mapperLocations" value="classpath:cn/baidu/template/dao/*.xml"/>-->

    </bean>

    <!-- 配置扫描Dao接口包,动态实现Dao接口,注入到spring容器中 -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <!-- 注入sqlSessionFactory -->
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
        <!-- 给出需要扫描Dao接口包 -->
        <property name="basePackage" value="www.longshine.baidu.dao"/>
    </bean>

    <!-- 配置事务管理器 -->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <!-- 注入数据库连接池 -->
        <property name="dataSource" ref="dataSource"/>
    </bean>

    <!-- 配置基于注解的声明式事务 -->
    <tx:annotation-driven transaction-manager="transactionManager"/>

    <!-- 引入其它配置文件 -->
    <!-- 定时任务 -->
    <!--    <import resource="applicationContext-springtask.xml"/>-->

    <!-- redis缓存 -->
    <!-- <import resource="applicationContext-redis.xml"/>-->

    <!-- spring aop -->
    <!-- 启动对@AspectJ注解的支持 -->
    <!--  <aop:aspectj-autoproxy/>-->

</beans>

1.2 jdbc.properties

jdbc.driver=com.mysql.jdbc.Driver
#数据库地址
jdbc.url=jdbc:mysql://localhost:3306/practies?useUnicode=true&characterEncoding=utf-8&autoReconnect=true
#用户名
jdbc.username=root
#密码
jdbc.password=123456
#最大连接数
c3p0.maxPoolSize=30
#最小连接数
c3p0.minPoolSize=10
#关闭连接后不自动commit
c3p0.autoCommitOnClose=false
#获取连接超时时间
c3p0.checkoutTimeout=10000
#当获取连接失败重试次数
c3p0.acquireRetryAttempts=2

1.3项目结构
截图是service层的测试类
在这里插入图片描述
1.4 依赖添加

<dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-aop</artifactId>
            <version>4.3.7.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-test</artifactId>
            <version>4.3.7.RELEASE</version>
        </dependency>

2 运行测试
在这里插入图片描述
在这里插入图片描述

单元测试报告 版本:V1.3 文 档 编 号 保 密 等 级 作 者 最后修改日期 审 核 人 最后审批日期 批 准 人 最后批准日期 修订记录 日期 版本 修订说明 修订人 目 录 1 简介 2 1.1 目的 2 1.2 背景 2 1.3 范围 2 2 测试用例清单 2 3 功能测试分析 2 4 边界测试分析 2 5 覆盖率分析 2 6 内存使用分析 2 7 典型缺陷记录 3 7.1 缺陷1 3 7.1.1 表现 3 7.1.2 原因 3 7.1.3 方案 3 8 测试数据分析 3 8.1 测试有效性分析 3 8.2 测试效率分析 3 9 产品质量分析 4 10 测试结论 4 简介 目的 【描述该单元测试报告的目的。】 背景 【描述单元测试报告的背景,单元测试活动目的。如无特殊背景信息,可裁剪。】 范围 【说明该单元测试报告在整个项目周期的适用范围】 测试用例清单 模块 目标类 级别 用例类 用例描述 执行结果 备注 【被测的代码类】 【代码级别】 【Junit测试类1】 【意图描述】 【P/F】 【Junit测试类2】 功能测试分析 边界测试分析 覆盖率分析 目标类 级别 方法覆盖率 行覆盖率 备注 【被测的代码类】 【代码级别】 内存使用分析 典型缺陷记录 记录单元测试中所发现的典型缺陷或常见缺陷。供再次发现同类问题时,作为参考使用。 缺陷1 表现 【缺陷表现描述】 原因 【缺陷产生原因分析描述】 方案 【解决方案描述】 测试有效性分析 【统计实际发现的缺陷数据,分析与计划值产生偏差的原因,结合《项目量化管理计划》定义的阈值,确定是否采取相关措施】 计划发现缺陷数 致命 严重 一般 实际发现缺陷数 偏差分析 对策或调整措施 产品质量分析 【结合上述数据和信息,对本次测试的项目、产品的本身质量进行分析、评价和总结】 测试结论  【描述测试是否达到测试计划的目的,是否满足单元测试的结束条件。】
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值