TestNG基本注解(一)
TestNG基本注解
| 注解 | 描述 |
|---|---|
| @BeforeSuite | 注解的方法将只运行一次,运行所有测试前此套件中。 |
| @AfterSuite | 注解的方法将只运行一次此套件中的所有测试都运行之后。 |
| @BeforeClass | 注解的方法将只运行一次先行先试在当前类中的方法调用。 |
| @AfterClass | 注解的方法将只运行一次后已经运行在当前类中的所有测试方法。 |
| @BeforeTest | 注解的方法将被运行之前的任何测试方法属于内部类的 <test>标签的运行。 |
| @AfterTest | 注解的方法将被运行后,所有的测试方法,属于内部类的<test>标签的运行。 |
| @BeforeGroups | 组的列表,这种配置方法将之前运行。此方法是保证在运行属于任何这些组第一个测试方法,该方法被调用。 |
| @AfterGroups | 组的名单,这种配置方法后,将运行。此方法是保证运行后不久,最后的测试方法,该方法属于任何这些组被调用。 |
| @BeforeMethod | 注解的方法将每个测试方法之前运行。 |
| @AfterMethod | 被注释的方法将被运行后,每个测试方法。 |
| @DataProvider |
标志着一个方法,提供数据的一个测试方法。注解的方法必须返回一个Object[] [],其中每个对象[]的测试方法的参数列表中可以分配。
该@Test 方法,希望从这个DataProvider的接收数据,需要使用一个dataProvider名称等于这个注解的名字。 |
| @Factory | 作为一个工厂,返回TestNG的测试类的对象将被用于标记的方法。该方法必须返回Object[]。 |
| @Listeners | 定义一个测试类的监听器。 |
| @Parameters | 介绍如何将参数传递给@Test方法。 |
| @Test | 标记一个类或方法作为测试的一部分。 |
1、作用域的不一样划分出了各种不同的标签:
一个套件(suite)包含多个测试(test)
一个测试(test)包含多个类(class)
一个测试(test)包含多个组(group)
一个类(class)包含多个方法(method)
2、定义组
在上述基本标签后均可以定义他们所属的组,定义如下:
@BeforeGroups(groups="test01")
public void group(){
System.out.println("I am a group!");
}
group方法属于test01这个组,只有当执行test01这个组时group方法才能执行。
每个防范可以属于多个组,定义如下:
@BeforeClass(groups={"test01","test02"})
public void classs(){
System.out.println("tAutoTest01-BeforeClass");
}
当执行test01和test02时该方法都会执行。
3、参数化
(1)、xml参数传递
代码定义:
@Test
@Parameters("myName")//可同时传递多个参数如:@Parameters({"myName","myName01"})
public void test01(String myName) {
System.out.println(myName);
}
xml定义:
<suite name="Suite" parallel="none">
<parameter name="myName" value="YinTing"></parameter>
<test name="Test">
<classes>
<class name="com.sword.test.tAutoTest01"></class>
</classes>
</test>
<test name="Test01">
<classes>
<class name="com.sword.test.tAutoTest"></class> <!-- 该值覆盖了前面定义的YinTing-->
</classes>
</test>
</suite> <!-- Suite -->
(2)、代码动态传递(数据提供者)
代码定义:
@DataProvider(name="TestData")//定义数据的提供者
public Object[][] data() {
return new Object[][]{{"YinTing",26},{"YangYi",24}};
}
@Test(dataProvider="TestData")//指定数据提供者
public void test01(String name,Integer age){
System.out.println("姓名:"+name+" "+"年龄:"+age);
}
4、工厂
策略:一般我们会在标有@Factory注解的方法中对测试类进行调用,这时TestNg会自动调用测试类中带有@Test注解的方法
工厂类代码定义:
package com.sword.test;
import org.testng.annotations.Factory;
public class tAutoFactory {
@Factory
public Object[] test01(){
Object test01[]=new Object[10];
for(int i=00;i<10;i++){
test01[i]=new tAutoTest01(i);
}
return test01;
}
}
Test类代码定义:
package com.sword.test;
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;
public class tAutoTest01 {
public int i=0;
public tAutoTest01(int i){
this.i=i;
}
@DataProvider(name="TestData")
public Object[][] data() {
return new Object[][]{{"YinTing",26},{"YangYi",24}};
}
@Test(dataProvider="TestData")
public void test01(String name,Integer age){
System.out.println("姓名:"+name+" "+"年龄:"+age);
System.out.println("-------------------"+this.i+"--------------------");
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
XML定义:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd">
<suite name="Suite" parallel="none">
<parameter name="myName" value="YinTing"></parameter>
<test name="Test">
<classes>
<class name="com.sword.test.tAutoFactory"></class>
</classes>
</test>
</suite> <!-- Suite -->
执行结果:
姓名:YinTing 年龄:26
-------------------7--------------------
姓名:YangYi 年龄:24
-------------------7--------------------
姓名:YinTing 年龄:26
-------------------5--------------------
姓名:YangYi 年龄:24
-------------------5--------------------
姓名:YinTing 年龄:26
-------------------2--------------------
姓名:YangYi 年龄:24
-------------------2--------------------
姓名:YinTing 年龄:26
-------------------4--------------------
姓名:YangYi 年龄:24
-------------------4--------------------
姓名:YinTing 年龄:26
-------------------3--------------------
姓名:YangYi 年龄:24
-------------------3--------------------
姓名:YinTing 年龄:26
-------------------6--------------------
姓名:YangYi 年龄:24
-------------------6--------------------
姓名:YinTing 年龄:26
-------------------8--------------------
姓名:YangYi 年龄:24
-------------------8--------------------
姓名:YinTing 年龄:26
-------------------1--------------------
姓名:YangYi 年龄:24
-------------------1--------------------
姓名:YinTing 年龄:26
-------------------0--------------------
姓名:YangYi 年龄:24
-------------------0--------------------
姓名:YinTing 年龄:26
-------------------9--------------------
姓名:YangYi 年龄:24
-------------------9--------------------
===============================================
Suite
Total tests run: 20, Failures: 0, Skips: 0
===============================================
5、监听器
该地址讲解的相当详细:http://www.ibm.com/developerworks/cn/opensource/os-cn-testinglistener/index.html
6、顺序执行测试&依赖测试&忽略测试
(1)、顺序执行测试
xml定义:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd">
<suite name="Suite" parallel="none">
<parameter name="myName" value="YinTing"></parameter>
<test name="Test" preserve-order="true"><!-- 顺序执行测试中的测试方法 -->
<classes>
<class name="com.sword.test.tAutoFactory"></class>
</classes>
</test>
</suite> <!-- Suite -->
(2)、依赖测试
代码定义:
package com.sword.test;
import org.testng.annotations.Test;
public class tAutoTest {
@Test
public void test02(){
System.out.println("I am test02!");
throw new RuntimeException();
}
@Test(dependsOnMethods="test02")//test01依赖test02的成功执行,才能执行。当test02抛出异常不能正常执行后,test01已不能执行。
public void test01(){
System.out.println("YinTing");
}
}
执行报告:
I am test02!
FAILED: test02
java.lang.RuntimeException
at com.sword.test.tAutoTest.test02(tAutoTest.java:10)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:84)
at org.testng.internal.Invoker.invokeMethod(Invoker.java:714)
at org.testng.internal.Invoker.invokeTestMethod(Invoker.java:901)
at org.testng.internal.Invoker.invokeTestMethods(Invoker.java:1231)
at org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:127)
at org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:111)
at org.testng.TestRunner.privateRun(TestRunner.java:767)
at org.testng.TestRunner.run(TestRunner.java:617)
at org.testng.SuiteRunner.runTest(SuiteRunner.java:335)
at org.testng.SuiteRunner.runSequentially(SuiteRunner.java:330)
at org.testng.SuiteRunner.privateRun(SuiteRunner.java:291)
at org.testng.SuiteRunner.run(SuiteRunner.java:240)
at org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:52)
at org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:86)
at org.testng.TestNG.runSuitesSequentially(TestNG.java:1224)
at org.testng.TestNG.runSuitesLocally(TestNG.java:1149)
at org.testng.TestNG.run(TestNG.java:1057)
at org.testng.remote.RemoteTestNG.run(RemoteTestNG.java:111)
at org.testng.remote.RemoteTestNG.initAndRun(RemoteTestNG.java:204)
at org.testng.remote.RemoteTestNG.main(RemoteTestNG.java:175)
SKIPPED: test01
===============================================
Default test
Tests run: 2, Failures: 1, Skips: 1
===============================================
(3)、忽略测试
代码定义:
package com.sword.test;
import org.testng.annotations.Test;
public class tAutoTest {
@Test(enabled=false)//该方法不会被执行。
public void test02(){
System.out.println("I am test02!");
}
@Test
public void test01(){
System.out.println("YinTing");
}
}
执行报告:
YinTing
PASSED: test01
===============================================
Default test
Tests run: 1, Failures: 0, Skips: 0
TestNG基本注解(一)的更多相关文章
- TestNG基本注解
TestNG的注解: 注解 描述 @BeforeSuite 注解的方法将只运行一次,运行所有测试前此套件中. @AfterSuite 注解的方法将只运行一次此套件中的所有测试都运行之后. @Befor ...
- 【转】TestNG常用注解
http://blog.csdn.net/d6619309/article/details/52435084 TestNG的注解大部分用在方法级别上.常用的注解列举如下: 1. Before类别和Af ...
- TestNG之注解的生命周期
有必要介绍一下TestNG注解的生命周期,先看一下官网支持的注解有 @BeforeSuite@AfterSuite@BeforeTest@AfterTest@BeforeGroups@AfterGro ...
- TestNG基本注解(注释)
传统的方式来表示JUnit3中的测试方法是测试自己的名字前缀.标记一个类中的某些方法,具有特殊的意义,这是一个非常有效的方法,但命名不很好的扩展(如果我们想添加更多标签为不同的框架?),而非缺乏灵活性 ...
- TestNG配置注解
以下是TestNG支持的注释列表: 注解 描述 @BeforeSuite 在该套件的所有测试都运行在注释的方法之前,仅运行一次. @AfterSuite 在该套件的所有测试都运行在注释方法之后,仅运行 ...
- TestNG系列之:TestNG基本注解(注释)
注解 描述 @BeforeSuite 注解的方法只运行一次,在当前suite所有测试执行之前执行 @AfterSuite 注解的方法只运行一次,在当前suite所有测试执行之后执行 @BeforeCl ...
- testng自定义注解
在testng中大部分的注解已经可以满足我们测试的需求,但是在测试的时候想要通过注解的方式加入自己测试一些内容,比如 测试项目 测试描述 验证点等信息,可通过自定义注解的方式实现. 具体操作步骤如下 ...
- TestNG基本注解(二)
1. Before类别和After类别注解 @BeforeSuite @AfterSuite @BeforeTest @AfterTest @BeforeClass @AfterClass @Befo ...
- TestNG常用注解
原文链接:https://www.yiibai.com/testng/basic-annotations.html 以下是TestNG支持的注释列表: 注解 描述 @BeforeSuite 在该 ...
随机推荐
- Spark应用远程调试
本来想用Eclipse的.然而在网上找了一圈,发现大家都在说IntelliJ怎样怎样好.我也受到了鼓励,遂决定在这台破机器上鼓捣一次IntelliJ吧. Spark程序远程调试,就是将本地IDE连接到 ...
- Robotframework集成jenkins执行用例
Robotframework+jenkins配置 假设我们完成了一个模块的用例设计,可是想晚上9点或凌晨运行,这时候该怎么实现呢?jenkins可以很好解决我们的疑难. Jenkins安装 这里简单说 ...
- Hadoop DistributedCache使用案例
背景 公司数据处理具有两个计算框架,单机框架和MR框架.眼下我已经抽象出一套API interface, 供业务计算开发者使用. 并分别在两个计算框架下实现了API的运行调度.应用开发者有时间须要通过 ...
- [读书笔记]《没人会告诉你的PPT真相》
这本书分了三部分.第一部分偏重于基础技能,其中分为三部分,打印.放映.保存.第二部分是进阶,分为模板下载.模板修改.增加自定义页面等.第三部分是打造商业范的PPT,分为商业范的特征,具体技能体现(重复 ...
- 架构师基本功:SOA
(以下内容为个人理解,可能不够全面和准确) SOA (service-oriented architecture),面向服务的架构 啥是SOA?网上的解释,玄而又玄.俺说点人话,也许不准确,但现阶段我 ...
- jquery获取兄弟元素
按照w3c school的指引,jquery中,要获得一个元素的兄弟,可以用 prev().next()两种方法.顾名思义,prev()获得前一个,next()获得后面一个. 问题是,如果存在前后兄弟 ...
- 设计模式-(9)中介者模式(swift)
在对象去耦合的模式中,有两种模式:中介者模式,观察者模式 一,概念 用一个中介对象来封装一系列的对象交互.中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互. 这个 ...
- 在myeclipse中拷贝一个工程,修改部署的名字
在MyEclipse中,经常练习的时候需要建立多个工程,但是为了方便,通常的作法是:复制一个工程,然后直接粘贴,但是,部署以后会发现,使用新的工程名访问不了,报404错误. 其原因是没有修改W ...
- Lightoj 1017 - Brush (III)
1017 - Brush (III) PDF (English) Statistics Forum Time Limit: 2 second(s) Memory Limit: 32 MB Sam ...
- 并不对劲的AC自动机
这像是能解决所有问题的样子(并不).AC自动机之所以叫AC自动机是因为它能解决所有AC自动机的题. 其实只能解决的是很多模式串匹配一个母串的问题. 把kmp中的next数组得到下一次跳转的位置看成特殊 ...