JUnit in Action Second Edition-20130906

ch02-internals


探索JUnit核心

CalculatorTest测试用例

public class CalculatorTest
{

    @Test
    public void add()
    {
        Calculator calculator = new Calculator();
        double result = calculator.add( 10, 50 );
        assertEquals( 60, result, 0 );
    }
}

JUnit在调用(执行)每个@Test方法之前,为测试类创建一个新的实例。这有助于提供测试方法之间的独立性。
JUnit通过org.junit.Asser类提供的assert()方法进行测试验证。当条件成立时,assert方法保持沉默,但条件不成立时立即抛出异常。
 

Junit的核心对象

JUnit概念责任
Assert让你去定义你想测试的条件。当条件成立时,assert方法保持沉默,但条件不成立时立即抛出异常。
测试

一个以@Test注释的方法定义了一个测试。为了运行这个方法,JUnit会创建一个包含类的新实例,然后调用这个被注释的方法。

测试类(TestCase)一个测试类是@Test的容器
SuiteSuite允许你将测试类归成一组
RunnerRunner类用来运行测试。JUnit4是向后兼容的,可以运行JUnit3的测试。

运行参数化测试

parameterized(参数化)的测试运行器允许你使用不同的参数多次运行同一个测试。

@RunWith(value=Parameterized.class)
public class ParameterizedTest {

    private double expected; 
    private double valueOne; 
    private double valueTwo; 

    @Parameters 
    public static Collection<Integer[]> getTestParameters() {
       return Arrays.asList(new Integer[][] {
          {2, 1, 1},  //expected, valueOne, valueTwo   
          {3, 2, 1},  //expected, valueOne, valueTwo   
          {4, 3, 1},  //expected, valueOne, valueTwo   
       });
    }

    public ParameterizedTest(double expected, 
       double valueOne, double valueTwo) {
       this.expected = expected;
       this.valueOne = valueOne;
       this.valueTwo = valueTwo;
    }

    @Test
    public void sum() {
       Calculator calc = new Calculator();
       assertEquals(expected, calc.add(valueOne, valueTwo), 0);
    } 
}

如果在测试类中没有提供任何运行器,那么JUnit将会使用一个默认的运行器。如果想JUnit使用某个特定的测试运行器,那么使用@RunWith注释来指定测试运行器类。

@RunWith(value=Parameterized.class)
public class ParameterizedTest {}

 

用Suite来组合测试

@RunWith(value = Suite.class)
@SuiteClasses(value = { TestCaseA.class })
public class TestSuiteA {}
@RunWith(value = Suite.class)
@SuiteClasses(value = { TestCaseB.class })
public class TestSuiteB {}

组合一组测试集

@RunWith(value = Suite.class)
@SuiteClasses(value = { TestSuiteA.class, TestSuiteB.class })
public class MasterTestSuite {}



为了使简单的事情可以保持简单,如果你没有提供一个自己的Suite,那么测试运行器会自动创建一个Suite。

对于本文第一个代码CalculatorTest测试用例而言,默认的Suite可以用以下代码来表示:

@RunWith(value = Suite.class)
@SuiteClasses(value = { CalculatorTest.class })
public class AllTests{}


 

 

 

 


 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值