Junit4知识梳理
一、junit官网
junit4:http://junit.org/junit4/
junit5:http://junit.org/junit5/
二、github
junit4: https://github.com/junit-team/junit4
junit5: https://github.com/junit-team/junit5
三、下载和安装
https://github.com/junit-team/junit4/wiki/Download-and-Install
三、junit4运行流程
@Test |
讲一个普通的方法修饰成测试方法 |
@BeforeClass |
修饰的方法会在所有的方法调用前被调用, 而且该方法是静态的,所以当测试类被加载后就会运行他, 而且在内存中他只会存在一份实例,比较适合加载配置文件 |
@AfterClass | 修饰的方式通常用来对资源的清理,如关闭数据库的连接 |
@Before | 会在每个@Test修饰的方法的前各执行一次 |
@After | 会在每个@Test修饰的方法的后各执行一次 |
三、junit4常用注解
1.@Test
1)@Test的两个属性
属性名 | 作用 | 实例 |
expected | 声明了该测试方法应该抛出一个异常,如果抛出了说明测试成功 | @Test{expected=XX.class} |
timeout |
设置测试方法的超时时间,超过时间测试方法就会停止 适用场景举例:比如有一个循环代码,循环控制条件不太好控制,这里 使用timeout就避免了一直等待 |
@Test{timeout=毫秒} |
2.@Ignore
代表所修饰的测试方法会被测试运行器所忽略
3.@RunWith
可以更改测试运行器,自定义自己的运行器(必须继承org.junit.runner.Runner)
四、断言的使用
具体使用方法可参考官方文档:https://github.com/junit-team/junit4/wiki/Assertions
五、测试套件的使用
当有多个测试类,一个一个测试太麻烦了,可以使用如下测试套件
package com.dechy.test; import org.junit.runner.RunWith;
import org.junit.runners.Suite; @RunWith(Suite.class)
@Suite.SuiteClasses({TaskTest1.class,TaskTest2.class,TaskTest3.class})
public class SuiteTest {
/**
* 1.测试套件就是组织测试类一起运行
*
* 写一个作为测试套件的入口类,这个类中不包含其他方法
* 更改测试运行器Suite.class
* 将要测试的类作为数组传到Suite.SuiteClasses({})
*/ }
六、junit的参数化设置
package com.dechy.util; import static org.junit.Assert.*; import java.util.Arrays;
import java.util.Collection; import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters; @RunWith(Parameterized.class)
public class ParameterTest {
/*
* .更改默认的测试运行器为RunWith(Parameterized.class)
* .声明变量来存放预期值 和结果值
* .声明一个返回值 为Collection的公共静态方法,并使用@Parameters进行修饰
* .为测试类声明一个带有参数的公共构造函数,并在其中为之声明变量赋值
*/
int expected =;
int input1 = ;
int input2 = ; @Parameters
public static Collection<Object[]> t() {
return Arrays.asList(new Object[][]{
{,,},
{,,}
}) ;
} public ParameterTest(int expected,int input1,int input2) {
this.expected = expected;
this.input1 = input1;
this.input2 = input2;
} @Test
public void testAdd() {
assertEquals(expected, new Calculate().add(input1, input2));
} }
Junit4知识梳理的更多相关文章
- [SQL] SQL 基础知识梳理(一)- 数据库与 SQL
SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...
- [SQL] SQL 基础知识梳理(二) - 查询基础
SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...
- [SQL] SQL 基础知识梳理(三) - 聚合和排序
SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...
- [SQL] SQL 基础知识梳理(四) - 数据更新
SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...
- [SQL] SQL 基础知识梳理(五) - 复杂查询
SQL 基础知识梳理(五) - 复杂查询 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5939796.html 序 这是<SQL 基础知识梳理( ...
- solr DIH 知识梳理
solr DIH 知识梳理 web.xml中listener配置 <listener> <listener-class>org.apache.solr.handler.data ...
- Anliven - 基础知识梳理汇总 - 软件测试
基础知识梳理 - 软件测试 - 概念 基础知识梳理 - 软件测试 - 分类 基础知识梳理 - 软件测试 - 流程 基础知识梳理 - 软件测试 - 用例 基础知识梳理 - 软件测试 - 方法 基础知识梳 ...
- [C# 基础知识梳理系列]专题六:泛型基础篇——为什么引入泛型
引言: 前面专题主要介绍了C#1中的2个核心特性——委托和事件,然而在C# 2.0中又引入一个很重要的特性,它就是泛型,大家在平常的操作中肯定会经常碰到并使用它,如果你对于它的一些相关特性还不是很了解 ...
- java基础知识梳理
java基础知识梳理 1 基本数据类型
随机推荐
- easyUi 表头排序按钮 bug
参考文章:https://www.shiqidu.com/p/81
- (转) VS2010 Addins 外接程序(插件)开发
http://www.cnblogs.com/Leo_wl/archive/2013/03/21/2973886.html VS2010 Addins 外接程序(插件)开发 阅读目录 VS2010 A ...
- centos 安装mysql数据库
在CentOS中默认安装有MariaDB,这个是MySQL的分支,但为了需要,还是要在系统中安装MySQL,而且安装完成之后可以直接覆盖掉MariaDB. 1 下载并安装MySQL官方的 Yum Re ...
- input 文本框,对中文长度校验
在项目中,经常会遇到,对文本框进行校验. eg. 要求姓名长度为20,中文为10,只能输入中英文. <input maxlength="20" type="t ...
- intelliJ IDEA 破解,亲测有效
https://blog.csdn.net/shengshengshiwo/article/details/79599761
- python return 及lambda函数
return有两个作用: 1.用来返回函数的运行结果,或者调用另外一个函数.比如max()函数 >>> def fun(a,b): #返回函数结果. return max(a,b) ...
- JMeter学习(五)集合点(转载)
转载自 http://www.cnblogs.com/yangxia-test JMeter也有像LR中的集合点,本篇就来介绍下JMeter的集合点如何去实现. JMeter里面的集合点通过添加定时器 ...
- 最长公共子序列hdu1503
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1503 题意:给你两个字符串,把这两个字符串合并,使合并之后的字符串最短,并且合并之后的字符之间的相对位 ...
- ansible1
前期工作: 第一步:下载epel源 wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo 第二步: ...
- MySQL之多表查询练习 与基本查询基础
MySQL 增删查改 一.增:有2种方法 1.使用insert插入单行数据: 语法:insert [into]<表名> [列名] values <列值> 例:insert i ...