总结TestNg与Junit的异同
相同点:
1.都可以做忽略测试,可以忽略某个测试方法(在方法上面注释),也可以忽略某个测试类(在类的上面注释)
testNg:
@Test(enabled = false)
Junit:
@Ingore
@Test
2.都支持数据驱动测试,只是用法不一样
testng中可以用@DataProvider,参数化是在测试级别的,不需要通过构造函数来传递参数,它会自动映射。
举例:
//表示这个方法将提供数据给任何声明它的data provider名为“test1”的测试方法中
@DataProvider(name = "test1")
public Object[][] createData1() {
return new Object[][] {
{ "Cedric", new Integer(36) },
{ "Anne", new Integer(37)},
};
}
//下面这个方法将要调用名为test1的data provider提供的数据
@Test(dataProvider="test1")
public void verifyDta(String n1,Integer n2){
System.out.println(n1 + " " + n2);
}
需要注意的是@Test(dataProvider=)和@DataProvider(name=)可以在同一个类中,使用方法如上;如果不在同一个类中,那么必须把@DataProvider(name=)所在的类的这个方法定义成static静态方法。
并且在@Test使用的时候需要制定类。用法是@Test(dataProvider="",dataProviderClass=(@DataProvider所在的类).class)
而在junit中麻烦多了。junit中的参数化是在类级别的,需要通过构造函数来传递参数。
如下:
package demo;
public class Try {
public int result=3;
public int add(int n) {
result += n;
return result;
}
}
测试代码:
package demo;
import static org.junit.Assert.assertEquals;
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;
//步骤1.指定特殊的运行器Parameterized.class
@RunWith(Parameterized.class)
public class TryTest {
// 步骤2:为测试类声明几个变量,分别用于存放期望值和测试所用数据。此处我只放了测试所有数据,没放期望值。
private int param, result;
// 步骤3:申明构造函数
public TryTest(int param, int result) {
super();
this.param = param;
this.result = result;
}
// 步骤4:定义测试数据的集合,该方法可以任意命名
// 但是必须使用@Parameters标注进行修饰
// 这个方法的框架不予解释了,大家只需要注意其中的数据,是一个二维数组,数据两两一组
// 每组中的这两个数据,一个是参数,一个是你预期的结果。
// 比如我们的第一组{4, 7},4是参数,7是预期的结果。分别对应上面构造函数的param和result
@Parameters
public static Collection<Object[]> testDate() {
Object[][] object = { { 1, 4 }, { 3, 6 }, { 1, 3 } };
return Arrays.asList(object);
}
// 步骤5:编写测试方法,使用定义的变量作为参数进行测试
// 这里的编写方法和以前的测试方法一样
@Test
public void testAdd() {
Try test = new Try();
assertEquals(result, test.add(param));
}
}
3.超时测试,是在规定时间内如果没有测试完成,认定测试失败
@Test(timeout=100)
4.异常测试,是在运行这个单元测试的时候应该要捕获到指定的异常,才算测试成功