JUnit4测试

1.测试方法上必须使用@Test进行修饰
2.测试方法必须使用public void 进行修饰,不能带任何的参数
3.新建一个源代码目录来存放我们的测试代码
4.测试类的包应该和被测试类保持一致
5.测试单元中的每个方法必须可以独立测试,测试方法间不能有任何的依赖
6.测试类使用Test作为类名的后缀(不是必须)
7.测试方法使用test作为方法名的前缀(不是必须)

项目的包结构一般如下:
这里写图片描述

需要测试的类:

package com.dlb.demo;

/**
 * 
 * @ClassName: Calculate
 * @Description: 计算类
 * @author cheng
 * @date 2017年9月17日 下午9:05:16
 */
public class Calculate {

    public int add(int a, int b) {
        return a + b;
    }

    public int subtract(int a, int b) {
        return a - b;
    }

    public int multiply(int a, int b) {
        return a * b;
    }

    public int divide(int a, int b) {
        return a / b;
    }

}

快速生成测试类:
选中需要测试的类(上面的Calculate 类),右键,new 》 JUnit Test Case,修改测试类代码路径(即修改Source folder)

修改Source folder
这里写图片描述

选择需要生成那些方法的测试方法
这里写图片描述

生成的测试类如下:

package com.dlb.demo;

import static org.junit.Assert.*;

import org.junit.After;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;

public class CalculateTest {

    @BeforeClass
    public static void setUpBeforeClass() throws Exception {
        System.out.println("@BeforeClass");
    }

    @AfterClass
    public static void tearDownAfterClass() throws Exception {
        System.out.println("@AfterClass");
    }

    @Before
    public void setUp() throws Exception {
        System.out.println("@Before");
    }

    @After
    public void tearDown() throws Exception {
        System.out.println("@After");
    }

    @Test
    public void testAdd() {
        // 断言(预期值,实际结果)
        assertEquals(6, new Calculate().add(3, 3));
        System.out.println("testAdd");
    }

    @Test
    public void testSubtract() {
        assertEquals(3, new Calculate().subtract(5, 2));
        System.out.println("testSubtract");
    }

    @Test
    public void testMultiply() {
        assertEquals(4, new Calculate().multiply(2, 2));
        System.out.println("testMultiply");
    }

    @Test
    public void testDivide() {
        assertEquals(3, new Calculate().divide(6, 2));
        System.out.println("testDivide");
    }

}

运行结果:

这里写图片描述

1.@BeforeClass修饰的方法会在所有方法被调用前被执行,而且该方法是静态的,所以当测试类被加载后接着就会运行它,而且在内存中它只会存在一份实例,它比较适合加载配置文件。
2.@AfterClass所修饰的方法通常用来对资源的清理,如关闭数据库的连接
3.@Before和@After会在每个测试方法的前后各执行一次。

运行所有的方法:

这里写图片描述

运行指定方法:

这里写图片描述

@Test:将一个普通的方法修饰成为一个测试方法
@Test(expected=XX.class)
用于捕获异常,即发生了该异常也不会报错
@Test(timeout=毫秒 )
方法运行不能超过该时间,用于测试性能或者关闭死循环

@BeforeClass:它会在所有的方法运行前被执行,static修饰
一般用于加载资源

@AfterClass:它会在所有的方法运行结束后被执行,static修饰
一般用于关闭资源

@Before:会在每一个测试方法被运行前执行一次

@After:会在每一个测试方法运行后被执行一次

@Ignore:所修饰的测试方法会被测试运行器忽略

@RunWith:可以更改测试运行器 org.junit.runner.Runner

    //即使以下方法运行时,发生ArithmeticException也不会报错
    @Test(expected=ArithmeticException.class)
    public void testDivide() {
        assertEquals(3, new Calculate().divide(6, 0));
    }

    //junit运行时不会运行该方法
    @Ignore("...")
    @Test(timeout=2000)
    public void testWhile() {
        while(true) {
            System.out.println("run forever...");
        }
    }

    //方法运行最长时间不能超过多少
    @Test(timeout=3000)
    public void testReadFile(){
        try {
            Thread.sleep(2000);
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

1.Failure一般由单元测试使用的断言方法判断失败所引起的,这经表示 测试点发现了问题,就是说程序输出的结果和我们预期的不一样。

2.error是由代码异常引起的,它可以产生于测试代码本身的错误,也可以是被测试代码中的一个隐藏的bug

3.测试用例不是用来证明你是对的,而是用来证明你没有错。

测试套件

测试套件就是组织测试类一起运行的
写一个作为测试套件的入口类,这个类里不包含其他的方法
更改测试运行器Suite.class
将要测试的类作为数组传入到Suite.SuiteClasses({})

import static org.junit.Assert.*;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.Suite;

@RunWith(Suite.class)
@Suite.SuiteClasses({TaskTest1.class,TaskTest2.class,TaskTest3.class})//TaskTest1,TaskTest2,TaskTest3表示要一起运行的测试类
public class SuiteTest {
}

参数化设置

1.更改默认的测试运行器为RunWith(Parameterized.class)
2.声明变量来存放预期值 和结果值
3.声明一个返回值 为Collection的公共静态方法,并使用@Parameters进行修饰
4.为测试类声明一个带有参数的公共构造函数,并在其中为之声明变量赋值

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 {

    int expected =0;
    int input1 = 0;
    int input2 = 0;

    @Parameters
    public static Collection<Object[]> t() {
        return Arrays.asList(new Object[][]{
                //有多少个数组就运行多少次方法
                {3,1,2},//期待值3,计算1+2
                {4,2,2}//期待值4,计算2+2
        }) ;
    }

    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));
    }

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值