异常测试
@Test(expectedExceptions = ReservationException.class)
public void shouldThrowIfPlaneIsFull(){
plane plane = createPlane();
plane.bookAllSeats();
plane.bookPlane(createVaildItinerary, null);
}
属性expectedExceptions是一组类,包含了这个测试方法中预期会抛出的异常列表。如果没有抛出异常,或抛出的异常不在该属性的列表中,那么TestNG就会认为这个测试方法失败了。反之,如果这个方法排除的异常在列表中,TestNG就会认为这个测试通过了。
利用@Test annotation来支持异常的测试有两个优点:
- 它使我们的意图变得非常清楚,只要读一下@Test annotation,就能立即知道预期将发生什么;
- 它消除了try/catch/fail空语句给代码带来的干扰
假设有两个测试,执行了代码的不同部分,但是它们初始化方式是一样的,我们就可以将这部分代码放到@BeforeMethod中去(因为我们希望在每次方法调用之前都重新创建这个对象)
public class BookingTest{
private Plane plane;
@BeforeMethod
public void init(){
plane=createPlane();
}
@Test(expectedExceptions = ReservationException.class)
public void shouldThrowIfPlaneIsFull(){
plane plane = createPlane();
plane.bookAllSeats();
plane.bookPlane(createVaildItinerary, null);
}
@Test(expectedExceptions = FlightCancleException.class)
public void shouldThrowIfFlightIsCancled(){
plane plane = createPlane();
cancleFlight(/*...*/);
plane.bookPlane(createVaildItinerary, null);
}
}
工厂
当通过命令行、ant或testng.xml将测试类传递给TestNG时,TestNG会调用它们的无参数构造方法,将这些类实例化,然后执行在每个类中找到的测试方法。
这里将介绍TestNG如何利用@Factory annotation来创建自己的实例
TestNG可以让你选择自己讲测试类实例化,这公司通过@Factory annotation来实现的,它必须放在返回一个对象数组方法的顶部。所有这些对象都必须包含TestNG annotation、如果有@Factory annotation,那么这个循环会继续下去,直到TestNG拿到的都是没有@Factory annotation实例,或者@Factory 方法都已被调用过的实例。
请注意,你可以安全的在同一个类中包含@Factory和@Test annotation,因为TestNG确保@Factory方法只执行一次。
由于@Factory方法可以在测试中添加新的测试类,它们总是首先调用的,在@Test方法和配置方法调用之前。只有当所有的@Factory方法被调用之后,TestNG才开始执行配置和测试方法。