注解 | 描述 |
---|---|
@BeforeSuite | 注解的方法将只运行一次,运行所有测试前此套件中。 |
@AfterSuite | 注解的方法将只运行一次此套件中的所有测试都运行之后。 |
@BeforeClass | 注解的方法将只运行一次先行先试在当前类中的方法调用。 |
@AfterClass | 注解的方法将只运行一次后已经运行在当前类中的所有测试方法。 |
@BeforeTest | 注解的方法将被运行之前的任何测试方法属于内部类的 <test>标签的运行。 |
@AfterTest | 注解的方法将被运行后,所有的测试方法,属于内部类的<test>标签的运行。 |
@BeforeGroups | 组的列表,这种配置方法将之前运行。此方法是保证在运行属于任何这些组第一个测试方法,该方法被调用。 |
@AfterGroups | 组的名单,这种配置方法后,将运行。此方法是保证运行后不久,最后的测试方法,该方法属于任何这些组被调用。 |
@BeforeMethod | 注解的方法将每个测试方法之前运行。 |
@AfterMethod | 被注释的方法将被运行后,每个测试方法。 |
@DataProvider | 标志着一个方法,提供数据的一个测试方法。注解的方法必须返回一个Object[] [],其中每个对象[]的测试方法的参数列表中可以分配。 该@Test 方法,希望从这个DataProvider的接收数据,需要使用一个dataProvider名称等于这个注解的名字。 |
@Factory | 作为一个工厂,返回TestNG的测试类的对象将被用于标记的方法。该方法必须返回Object[]。 |
@Listeners | 定义一个测试类的监听器。 |
@Parameters | 介绍如何将参数传递给@Test方法。 |
@Test | 标记一个类或方法作为测试的一部分。 |
TestNG中如何执行测试
第一种直接执行:右键要执行的方法, 点Run As ->TestNG Test
第二种: 通过testng.xml文件来执行. 把要执行的case, 放入testng.xml文件中。 右键点击testng.xml, 点Run As
testng.xml
1.
<?xml version=
"1.0"
encoding=
"UTF-8"
?><!DOCTYPE suite SYSTEM
"http://testng.org/testng-1.0.dtd"
>
2.
<suite name=
"Suite1"
>
3.
<test name=
"test12"
>
4.
<classes>
5.
<
class
name=
"TankLearn2.Learn.TestNGLearn1"
/>
6.
</classes>
7.
</test>
8.
</suite>
TestNG按顺序执行Case
在testng.xml中,可以控制测试用例按顺序执行。 当preserve-order="true"是,可以保证节点下面的方法是按顺序执行的
01.
<?xml version=
"1.0"
encoding=
"UTF-8"
?><!DOCTYPE suite SYSTEM
"http://testng.org/testng-1.0.dtd"
>
02.
<suite name=
"Suite1"
>
03.
<test name=
"test12"
preserve-order=
"true"
>
04.
<classes>
05.
<
class
name=
"TankLearn2.Learn.TestNGLearn1"
>
06.
<methods>
07.
<include name=
"TestNgLearn3"
/>
08.
<include name=
"TestNgLearn1"
/>
09.
<include name=
"TestNgLearn2"
/>
10.
</methods>
11.
</
class
>
12.
</classes>
13.
</test>
14.
</suite>
TestNG异常测试
测试中,有时候我们期望某些代码抛出异常。
TestNG通过@Test(expectedExceptions) 来判断期待的异常, 并且判断Error Message
01.
package
TankLearn2.Learn;
02.
03.
import
org.testng.annotations.Test;
04.
05.
public
class
ExceptionTest {
06.
07.
@Test
(expectedExceptions = IllegalArgumentException.
class
, expectedExceptionsMessageRegExp=
"NullPoint"
)
08.
public
void
testException(){
09.
throw
new
IllegalArgumentException(
"NullPoint"
);
10.
}
11.
}
TestNG组测试
TestNG中可以把测试用例分组,这样可以按组来执行测试用例比如:
01.
package
TankLearn2.Learn;
02.
03.
import
org.testng.annotations.Test;
04.
05.
public
class
GroupTest {
06.
07.
@Test
(groups = {
"systemtest"
})
08.
public
void
testLogin(){
09.
System.out.println(
"this is test login"
);
10.
}
11.
12.
@Test
(groups = {
"functiontest"
})
13.
public
void
testOpenPage(){
14.
System.out.println(
"this is test Open Page"
);
15.
}
16.
}
然后在testng.xml中 按组执行测试用例
01.
<?xml version=
"1.0"
encoding=
"UTF-8"
?>
02.
<!DOCTYPE suite SYSTEM
"http://testng.org/testng-1.0.dtd"
>
03.
<suite name=
"Suite1"
>
04.
<test name=
"test1"
>
05.
<groups>
06.
<run>
07.
<include name=
"functiontest"
/>
08.
</run>
09.
</groups>
10.
</test>
11.
</suite>
TestNG参数化测试
软件测试中,经常需要测试大量的数据集。 测试代码的逻辑完全一样,只是测试的参数不一样。 这样我们就需要一种 “传递测试参数的机制”。 避免写重复的测试代码
TestNG提供了2种传递参数的方式。
第一种: testng.xml 方式使代码和测试数据分离,方便维护
第二种:@DataProvider能够提供比较复杂的参数。 (也叫data-driven testing)
方法一: 通过testng.xml 传递参数给测试代码
01.
package
TankLearn2.Learn;
02.
03.
import
org.testng.annotations.Parameters;
04.
import
org.testng.annotations.Test;
05.
06.
public
class
ParameterizedTest1 {
07.
08.
@Test
09.
@Parameters
(
"test1"
)
10.
public
void
ParaTest(String test1){
11.
System.out.println(
"This is "
+ test1);
12.
}
13.
}
testng.xml
01.
<?xml version=
"1.0"
encoding=
"UTF-8"
?><!DOCTYPE suite SYSTEM
"http://testng.org/testng-1.0.dtd"
>
02.
<suite name=
"Suite1"
>
03.
<parameter name=
"test1"
value=
"Tank"
/>
04.
<parameter name=
"test1"
value=
"Xiao"
/>
05.
<test name=
"test12"
>
06.
<classes>
07.
<
class
name=
"TankLearn2.Learn.ParameterizedTest1"
/>
08.
</classes>
09.
</test>
10.
</suite>
方式二: 通过DataProvider传递参数
01.
package
TankLearn2.Learn;
02.
03.
import
org.testng.annotations.DataProvider;
04.
import
org.testng.annotations.Test;
05.
06.
public
class
DataProviderLearn {
07.
08.
@DataProvider
(name=
"user"
)
09.
public
Object[][] Users(){
10.
return
new
Object[][]{
11.
{
"root"
,
"passowrd"
},
12.
{
"cnblogs.com"
,
"tankxiao"
},
13.
{
"tank"
,
"xiao"
}
14.
};
15.
}
16.
17.
@Test
(dataProvider=
"user"
)
18.
public
void
verifyUser(String userName, String pass<a href=
"http://www.it165.net/edu/ebg/"
target=
"_blank"
class
=
"keylink"
>word</a>){
19.
System.out.println(
"Username: "
+ userName +
" Pass<a href="
http:
//www.it165.net/edu/ebg/" target="_blank" class="keylink">word</a>: "+ password);
20.
}
21.
}
TestNG忽略测试
有时候测试用例还没准备好, 可以给测试用例加上@Test(enable = false), 来禁用此测试用例
01.
package
TankLearn2.Learn;
02.
03.
import
org.testng.annotations.Test;
04.
05.
public
class
TesgNGIgnore {
06.
07.
@Test
(enabled =
false
)
08.
public
void
testIgnore(){
09.
System.out.println(
"This test case will ignore"
);
10.
}
11.
}
TestNG 依赖测试
有时候,我们需要按顺序来调用测试用例, 那么测试用例之间就存在依赖关系。 TestNG支持测试用例之间的依赖
01.
package
TankLearn2.Learn;
02.
03.
import
org.testng.annotations.Test;
04.
05.
public
class
DependsTest {
06.
07.
@Test
08.
public
void
setupEnv(){
09.
System.out.println(
"this is setup Env"
);
10.
}
11.
12.
@Test
(dependsOnMethods = {
"setupEnv"
})
13.
public
void
testMessage(){
14.
System.out.println(
"this is test message"
);
15.
}
16.
}
TestNG测试结果报告
测试报告是测试非常重要的部分.
TestNG默认情况下,会生产两种类型的测试报告HTML的和XML的。 测试报告位于 "test-output" 目录下.
当然我们也可以设置测试报告的内容级别.
verbose="2" 标识的就是记录的日志级别,共有0-10的级别,其中0表示无,10表示最详细
1.
<?xml version=
"1.0"
encoding=
"UTF-8"
?><!DOCTYPE suite SYSTEM
"http://testng.org/testng-1.0.dtd"
>
2.
<suite name=
"Suite1"
>
3.
<test name=
"test12"
verbose=
"2"
>
4.
<classes>
5.
<
class
name=
"TankLearn2.Learn.TestNGLearn1"
/>
6.
</classes>
7.
</test>
8.
</suite>