JUnit

JUnit是用于编写可重复测试的单元测试框架,可实现自动化测试。
JUnit官方API文档:http://junit.org/junit4/javadoc/latest/index.html

创建测试类

以下内容使用Eclipse

添加JUnit library

Build Path - Add Libraries - JUnit

新建测试类

右键待测试类 - New - Other (Ctrl + N) - JUnit Test Case - Next - Select methods - Finished

命名规范

被测试类名为MyClass,位于默认source folder中的包com.mydemo.util。

package com.mydemo.util;
public class MyClass {
    public static int add(int a, int b) {
        return a + b;
    }
}

新建source folder (可命名为test) 存放测试代码,在该folder下创建与被测试类同名包。测试类命名为MyClassTest,方法命名为testMethodName。测试方法前需加@Test,测试方法不能带参数,且必须为public void。

package com.mydemo.util;
import static org.junit.Assert.*;
import org.junit.Test;
import com.mydemo.util.MyClass;
public class MyClassTest {
    @Test
    public void testAdd() {
        assertEquals(6, MyClass.add(3, 3));
    }
}

使用测试类

运行测试类

测试失败

测试失败包括failure和error两种情况:

  • Failure是断言内容不匹配,如
    assertEquals(5, MyClass.add(3, 3));
  • Error是程序存在Error或未处理的Exception,如
    assertEquals(6, MyClass.add(3, a));
    assertEquals(6, MyClass.divide(3, 0));

失败时,JUnit测试工具显示红色条,Failure Trace显示原因和位置。

注解Annotation

@Test

将普通方法注释为测试方法,方法内部使用断言,断言失败时测试失败。

  • @Test(expected = ExceptionName.class)
    表示预期会抛出的异常,如抛出声明类型的异常测试仍然显示成功。
  • @Test(timeout = milliseconds)
    表示超出时间测试程序自动结束并显示为失败,时间单位为毫秒。

@BeforeClass, @AfterClass, @Before, @After

  • @BeforeClass
    该方法在所有的方法运行前被执行,必须为static。当测试类被加载后接着就会被运行,且在内存中只会存在一份实例。可用于加载配置文件。
  • @AfterClass
    该方法在所有的方法运行结束后被执行,必须为static。通常用来对资源的清理,如关闭数据库的连接。
  • @Before, @After
    分别在每一个测试方法运行前、后被执行一次。可用于初始化变量或重置变量等。

@Ignore

被注释的测试方法会被测试运行器忽略,测试时不执行。

@RunWith

可以更改测试运行器,运行器需继承org.junit.runner.Runner。

测试套件

可用于多个测试类的同时测试。测试套件基本结构如下:

package com.mydemo.util;

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

@RunWith(Suite.class)
@Suite.SuiteClasses({Test1.class,Test2.class,Test3.class, Suite1.class})
public class SuiteTest {
}
  • 创建测试套件类SuiteTest.class,作为测试套件的入口类,这个类不包含任何方法
  • @RunWith(Suite.class) 更改测试运行器,避免使用JUnit默认测试运行器。
  • @Suite.SuiteClasses({}) 添加测试类到测试套件中,参数为数组形式的测试类或测试套件类。

参数化测试

package com.mydemo.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 {
    // 声明变量存放预期值和测试数据
    int expected =0;
    int input1 = 0;
    int input2 = 0;
    // public构造函数给预期值和测试数据赋值
    public ParameterTest(int expected,int input1,int input2) {
        this.expected = expected;
        this.input1 = input1;
        this.input2 = input2;
    }
    // 返回值为Collection的public static方法,返回测试数据集合,用@Parameters修饰
    @Parameters
    public static Collection data() {
        return Arrays.asList(new Object[][]{
                {3,1,2},
                {4,2,2}
        }) ;
    }
    @Test
    public void testAdd() {
        assertEquals(expected, MyClass.add(input1, input2));
    }
}

参考资料

http://junit.org/junit4/
http://www.imooc.com/learn/356

你可能感兴趣的:(JUnit)