Android

Android JUnit单元测试

2019-02-16  本文已影响23人  斌林诚上
image

前言

为了减少上线bug出现几率,并提高编写代码的质量。抽空学习了一下单元测试。

之前一直很抵触自己写测试,主要分析有以下原因:

1、编写单元测试太花时间了(结果发现自己调试要花更多时间)
2、 运行测试的时间太长了(需要把耗时的测试和其他测试分开)
3、测试代码并不是我的工作(我们工作就是保证代码能够正确执行,所以测试代码也是必不可缺少的工作。)
4、公司请我来是为了写代码,而不是写测试(公司付给你薪水是为了让你编写产品代码,而单元测试大体上是一个工具,是一个和编辑器、开发环境、编译器等处于同一位置的工具)

经以上分析,不难看出——————————————————————作者都是从百度上抄的

image

一、简介

所谓单元测试是测试应用程序的功能是否能够按需要正常运行,是一个对单一实体(类或方法)的测试。单元测试是每个软件公司提高产品质量、满足客户需求的重要环节。单元测试可分为两种方式:人工测试与自动测试,人工测试顾名思义就是手动执行测试用例并不借助任何测试工具。而自动测试是借助工具支持并且利用自动工具执行测试用例。也是该文章介绍的重点。

1、那么Junit是什么呢?

JUnit 是一个 Java 编程语言的单元测试框架。

2、那Junit有什么用?

利用Junit可以更简单的编写单元测试用例,加快程序编制速度,同时提高编码的质量。

特点:

  1. JUnit 是一个开放的资源框架,用于编写和运行测试。
  2. 提供注释来识别测试方法。
  3. 提供断言来测试预期结果。
  4. 提供测试运行来运行测试。
  5. JUnit 测试允许你编写代码更快,并能提高质量。
  6. JUnit 优雅简洁。没那么复杂,花费时间较少。
  7. JUnit 测试可以自动运行并且检查自身结果并提供即时反馈。所以也没有必要人工梳理测试结果的报告。
  8. JUnit 测试可以被组织为测试套件,包含测试用例,甚至其他的测试套件。
  9. JUnit 在一个条中显示进度。如果运行良好则是绿色;如果运行失败,则变成红色。

扯不下去了,坑爹作者向你丢了一坨乱码

二、基本配置

测试运行在本地开发环境的Java虚拟机上,无需连接Android设备或模拟器。
因此,无法获得Android相关的API,只能测试只使用Java API的一些功能。

**--------忘了这句是从哪抄的 **

build.gradle 添加引用

    testImplementation 'junit:junit:4.12'
image.gif

编写需要测试的类

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;
    }
}
image.gif

右击GO TO——Test——create New Test

image

生成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("类结束时调用一次");
    }

}
image.gif

最后贴一下运行方式 》右击——Run 测试类

image

执行结果:

image

测试类里面代码怎么这么多,有点蒙逼。 这么麻烦还写它干嘛,那么让我们来看看语法,有些方法有时是不需要写出来的 。

三、注解

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 {}
image.gif
//测试类1
public class TaskTest {
    @Test
    public void add() {
        System.out.println("TaskTest");
    }
}
image.gif
//测试类2
public class TaskTest1 {
    @Test
    public void add() {
        System.out.println("TaskTest1");
    }
}
image.gif

参数化测试:对于一个方法需要进行多种场景进行测试时,可以通过参数化测试减少测试的工作量。

使用步骤:
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));
    }

}
image.gif

目前就了解这么多 顺便做了下笔记 如有雷同 纯属巧合
希望对大家有用。。。后续有新的知识、会保持继续更新

image

四、总结

注意事项:

测试失败说明:

五、参考文档

https://developer.android.google.cn/reference/junit/framework/Assert

https://wiki.jikexueyuan.com/project/junit/overview.html

六、内容推荐

CSDN:https://blog.csdn.net/cs_lwb/article/details/86002878

《Android 初识DataBinding》

如果你觉得我写的不错或者对您有所帮助的话

不妨顶一个【微笑】,别忘了点赞、收藏、加关注哈

您的每个举动都是对我莫大的支持

image
上一篇 下一篇

猜你喜欢

热点阅读