前言
为了减少上线bug出现几率,并提高编写代码的质量。抽空学习了一下单元测试。
之前一直很抵触自己写测试,主要分析有以下原因:
1、编写单元测试太花时间了(结果发现自己调试要花更多时间)
2、 运行测试的时间太长了(需要把耗时的测试和其他测试分开)
3、测试代码并不是我的工作(我们工作就是保证代码能够正确执行,所以测试代码也是必不可缺少的工作。)
4、公司请我来是为了写代码,而不是写测试(公司付给你薪水是为了让你编写产品代码,而单元测试大体上是一个工具,是一个和编辑器、开发环境、编译器等处于同一位置的工具)
经以上分析,不难看出——————————————————————作者都是从百度上抄的
一、简介
所谓单元测试是测试应用程序的功能是否能够按需要正常运行,是一个对单一实体(类或方法)的测试。单元测试是每个软件公司提高产品质量、满足客户需求的重要环节。单元测试可分为两种方式:人工测试与自动测试,人工测试顾名思义就是手动执行测试用例并不借助任何测试工具。而自动测试是借助工具支持并且利用自动工具执行测试用例。也是该文章介绍的重点。
1、那么Junit是什么呢?
JUnit 是一个 Java 编程语言的单元测试框架。
2、那Junit有什么用?
利用Junit可以更简单的编写单元测试用例,加快程序编制速度,同时提高编码的质量。
特点:
- JUnit 是一个开放的资源框架,用于编写和运行测试。
- 提供注释来识别测试方法。
- 提供断言来测试预期结果。
- 提供测试运行来运行测试。
- JUnit 测试允许你编写代码更快,并能提高质量。
- JUnit 优雅简洁。没那么复杂,花费时间较少。
- JUnit 测试可以自动运行并且检查自身结果并提供即时反馈。所以也没有必要人工梳理测试结果的报告。
- JUnit 测试可以被组织为测试套件,包含测试用例,甚至其他的测试套件。
- JUnit 在一个条中显示进度。如果运行良好则是绿色;如果运行失败,则变成红色。
扯不下去了,坑爹作者向你丢了一坨乱码
二、基本配置
测试运行在本地开发环境的Java虚拟机上,无需连接Android设备或模拟器。
因此,无法获得Android相关的API,只能测试只使用Java API的一些功能。
**--------忘了这句是从哪抄的 **
build.gradle 添加引用
testImplementation 'junit:junit:4.12'
编写需要测试的类
alculation.java
public class Calculation {
/**
* 加法
*/
public static int add(int a,int b){
return a+b;
}
/**
* 减法
*/
public static int sub(int a,int b){
return a-b;
}
}
右击GO TO——Test——create New Test
生成CalculationTest.java测试类,然后自己补充测试类
public class CalculationTest {
Calculation calculation;
@BeforeClass
public static void start() throws Exception {
System.out.println("类运行时调用一次");
}
@Before
public void before() throws Exception{
calculation = new Calculation();
System.out.println("每个test方法前都会调用");
}
@Test
public void add() {
System.out.println("test add");
int r = calculation.add(2,3);
Assert.assertEquals(5,r);
}
@Test
public void multiply() throws Exception {
System.out.println("test multiply");
int r = calculation.sub(6,3);
Assert.assertEquals(3,r);
}
@After
public void after() throws Exception {
System.out.println("每个test方法后都会调用");
}
@AfterClass
public static void end() throws Exception {
System.out.println("类结束时调用一次");
}
}
最后贴一下运行方式 》右击——Run 测试类
执行结果:
测试类里面代码怎么这么多,有点蒙逼。 这么麻烦还写它干嘛,那么让我们来看看语法,有些方法有时是不需要写出来的 。
三、注解
JUnit 4 注解
@Before :标注setup方法,每个单元测试用例方法调用之前都会调用 |
@After :标注teardown方法,每个单元测试用例方法调用之后都会调用 |
@Test :标注的每个方法都是一个测试用例 |
@BeforeClass :标注的静态方法,在当前测试类所有用例方法执行之前执行 |
@AfterClass :标注的静态方法,在当前测试类所有用例方法执行之后执行 |
@Test(timeout=) :为测试用例指定超时时间 |
@BeforeClass:这个注解表示这个方法会在所有测试方法执行之前执行, 因为是static修饰的静态方法,所有只会执行一次。通常用来进行一些 资源的加载。
@AfterClass:这个注解表示这个方法会在所有方法执行完毕之后执行,通常用来释放资源
@Before:这个注解表示这个方法会在每个测试方法执行之前执行一次 有多少个测试方法就会执行多少次
@After:这个注解表示这个方法会在每个测试方法执行之后执行一次 有多少个测试方法就会执行多少次
@Test:junit的测试方法必须使用@Test注解 测试方法必须以public void修饰,并且不包含参数
JUnit断言
assertTrue(condition) : condition为真pass,否则fail |
assertFalse(condition) :condition为假pass,否则fail |
fail() :直接fail |
assertEquals(expected, actual) :expected equal actual pass,否则fail |
assertSame(expected, actual) :expected == actual pass,否则fail |
测试筛选
@RequiresDevice :指定测试仅在物理设备而不在模拟器上运行 |
@SdkSupress :禁止在低于给定级别的 Android API 级别上运行测试
例如,@SdkSupress(minSdkVersion=18) |
@SmallTest、@MediumTest和@LargeTest: 指定测试的运行时长以及运行频 |
测试套件:如果要同时测试多个类,可以新增一个测试套件,将多个所有测试类包含进去,每次执行测试套件类的时候,就会把包含的测试类全都执行一遍,测试套件是用来组织多个测试类一起运行的,使用 @RunWith注解更改测试运行器为Suite.class,将要测试的类作为数组传入到Suite.SuiteClasses({})中,测试套件类不能包含其他测试方法
@RunWith(Suite.class)
@Suite.SuiteClasses({ TaskTest.class, TaskTest1.class})
public class SuiteTest {}
//测试类1
public class TaskTest {
@Test
public void add() {
System.out.println("TaskTest");
}
}
//测试类2
public class TaskTest1 {
@Test
public void add() {
System.out.println("TaskTest1");
}
}
参数化测试:对于一个方法需要进行多种场景进行测试时,可以通过参数化测试减少测试的工作量。
使用步骤:
1、更改测试运行器为RunWith(Parameterized.class)
2、声明变量用来存放预期值与结果值
3、声明一个返回值为Collection的公共静态方法,并使用@Parameters进行修饰
4、位测试类声明一个带有参数的公共构造方法,并在其中为声明变量赋值
@RunWith(Parameterized.class)
public class ParameterTest {
int except; //用来存储预期结果
int input1; //用来存储第一个输入参数
int input2; //用来存储第二个输入参数
@Parameters
public static Collection<Object[]> initTestData(){
return Arrays.asList(
new Object[][]{
{3,1,2},
{10,5,5},
{6,4,2},
{7,3,4}}
);
}
public ParameterTest(int except,int input1,int input2){
this.except = except;
this.input1 = input1;
this.input2 = input2;
}
@Test
public void testAdd() {
assertEquals(except, new Claculate().add(input1, input2));
}
}
目前就了解这么多 顺便做了下笔记 如有雷同 纯属巧合
希望对大家有用。。。后续有新的知识、会保持继续更新
四、总结
注意事项:
- 测试方法必须使用@Test修饰
- 测试方法必须使用public void进行修饰,不能带参数
- 一般使用单元测试会新建一个test目录存放测试代码,在生产部署的时候只需要将test目录下代码删除即可
- 测试代码的包应该和被测试代码包结构保持一致
- 测试单元中的每个方法必须可以独立测试,方法间不能有任何依赖
- 测试类一般使用Test作为类名的后缀
- 测试方法使一般用test作为方法名的前缀
测试失败说明:
- Failure:一般是由于测试结果和预期结果不一致引发的,表示测试的这个点发现了问题
- error:是由代码异常引起的,它可以产生于测试代码本身的错误,也可以是被测试代码中隐藏的bug
五、参考文档
https://developer.android.google.cn/reference/junit/framework/Assert
六、内容推荐
CSDN:https://blog.csdn.net/cs_lwb/article/details/86002878
如果你觉得我写的不错或者对您有所帮助的话
不妨顶一个【微笑】,别忘了点赞、收藏、加关注哈
您的每个举动都是对我莫大的支持