首先,把这三个定义简单的说明一下:
1、测试类(TestCase):一个包含一个或是多个测试的类,在Junit中就是指的是包含那些带有@Test注解的方法的类,同一样也被称作“测试用例”;
2、测试集(TestSuite):测试集是把多个相关测试归入一个组的表达方式,在Junit中,如果我们没有明确的定义一个测试集,那么Juint会自动的提供一个测试集,一个测试集一般将同一个包的测试类归入一组;
3、测试运行器(TestRunner):执行测试集的程序。
定义说完了,还有两个好理解的定义:断言(assert)和测试(Test),加上这两个定义,从断言到测试运行器就是从“原子”到“分子”的过程,“原子”组成“分子”的,“分子”包含若干”原子“。
关于测试类就比较好理解了,这里就不再拿出来说了,具体的说一说测试集与测试运行器吧。
一、测试运行器:
本文开篇已经说了关于测试运行器的概念,比较简单:执行测试集的程序,而在Junit中,我们使用测试运行器的方式也特别的简单,主要的是使用Junit的@RunnWith注解
- import org.junit.runner.RunWith;
- import org.junit.runners.JUnit4;
- @RunWith(value=JUnit4.class)
- public class TestRunner {
- }
运行器 | 目的 |
org.junit.internal.runners.JUnit38ClassRunner | 为了向后兼容Junit3.8的运行器 |
org.junit.runners.JUnit4 | Junit4的测试运行器 |
org.junit.runners.Parameterized | 可以使用不同参数来运行相同测试集的运行器 |
org.junit.runners.Suite | 包含不同测试的容器 |
Parameterized(参数化)的测试运行器允许我们使用不同的参数多此运行同一个测试,
比如我们在测试一个提供乘法算数的方法时,我们可以为测试用例提供三组数据:4*5(两个正整数)、-4*5(一正一负)、0*5(0与正整数),提供多组数据可以让我们从不同的角度对同一个方法进行测试,
具体的实现如下:
- package org.yezi.junit;
- public class Calcaute {
- public int ride(int a, int b){
- return a * b;
- }
- }
- package org.yezi.junit;
- import static org.junit.Assert.*;
- import java.util.ArrayList;
- import java.util.Collection;
- import java.util.List;
- import org.junit.*;
- import org.junit.runner.RunWith;
- import org.junit.runners.Parameterized;
- import org.junit.runners.Parameterized.Parameters;
- @RunWith(value=Parameterized.class)
- public class TestCalcaute {
- private Calcaute calcaute = null;
- private int expected;
- private int valueOne;
- private int valueTwo;
- @Parameters
- public static Collection<Integer[]> getTestParameters(){
- List<Integer[]> list = new ArrayList<Integer[]>();
- list.add(new Integer[]{ 20,4,5}); //expected,valueOne,valueTwo
- list.add(new Integer[]{-20,-4,5});
- list.add(new Integer[]{ 0,0,5});
- return list;
- }
- public TestCalcaute(int expected, int valueOne, int valueTwo){
- this.expected = expected;
- this.valueOne = valueOne;
- this.valueTwo = valueTwo;
- }
- @Before
- public void setUp(){
- calcaute = new Calcaute();
- }
- @Test
- public void testAdd(){
- int result = calcaute.ride(valueOne, valueTwo);
- assertEquals(expected, result);
- }
- }
ok,功能实现了,但是,在此我们要说明几个必须:
1、实现参数化测试运行器,该类必须加上@RunWith(value=Parameterized.class)注解!否则运行Junit报java.lang.Exception: Test class should have exactly one public zero-argument constructor异常
2、必须把测试的期望结果、以及测试参数声明为全局的、私有的!
3、必须创建一个带期望结果、测试参数的构造方法!
4、必须创建一个返回若干个测试参数、期望结果组的静态方法,返回类型为Collection<Integer[]>,并且该方法加以@Parameters( org.junit.runners.Parameterized.Parameters)注解!