JUnit

作者: lllaser | 来源:发表于2017-06-11 22:45 被阅读0次

    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<Object[]> 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

          本文链接:https://www.haomeiwen.com/subject/xxlkqxtx.html