章节十六、9-Listeners监听器
一、IInokedMethodListener
1、实现一个类来监听testcase的运行情况。
package listenerspackage; import org.testng.IInvokedMethod;
import org.testng.IInvokedMethodListener;
import org.testng.ITestResult; /**
* 监听*/ //所有监听的方法都由接口提供,所以我们需要先实现接口
public class CustomerListeners1 implements IInvokedMethodListener{ // beforeInvocation 和afterInvocation这两个方法时接口中已经写好的,我们需要按照需求将主体部分描述完整 // 调用前发生,在testcase类中的每个方法运行前执行
@Override
public void beforeInvocation(IInvokedMethod method, ITestResult testResult) {
// .getTestClass():返回测试方法所在的测试类,是类类型的
// .getName():返回类的类名
System.out.println("before Invocation:"+testResult.getTestClass().getName()+" -> "+method.getTestMethod().getMethodName());
} // 调用后发生,在testcase类中的每个方法运行结束后执行
@Override
public void afterInvocation(IInvokedMethod method, ITestResult testResult) {
System.out.println("after Invocation:"+testResult.getTestClass().getName()+" -> "+method.getTestMethod().getMethodName());
}
}
2、创建一个被监听的类
package testclasses1; import org.testng.Assert;
import org.testng.annotations.AfterClass;
import org.testng.annotations.BeforeClass;
import org.testng.annotations.Listeners;
import org.testng.annotations.Test; import listenerspackage.CustomerListeners1; //表示该测试类被CustomerListeners1类监听
@Listeners(CustomerListeners1.class)
public class TestNG_ListenersTest1 { @BeforeClass
public void setUp() {
System.out.println("Code in before class");
} @AfterClass
public void classUp() {
System.out.println("Code in after class");
} @Test
public void testMethod1() {
System.out.println("Code in testMethod1");
Assert.assertTrue(true);
} @Test
public void testMethod2() {
System.out.println("Code in testMethod2");
Assert.assertTrue(false);
}
}
3、配置xml
<!-- 没有此行配置运行时可能会报错 -->
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name="Listeners TestSuite">
<test name="Application Test">
<classes>
<class name="testclasses1.TestNG_ListenersTest1"></class>
</classes>
</test>
</suite>
4、运行结果
未加监听器前运行结果:
添加监听器后运行结果:
二、 ITestListener
1、实现ITestListener接口来监听testcase的运行情况。
package listenerspackage; import org.testng.ITestContext;
import org.testng.ITestListener;
import org.testng.ITestNGMethod;
import org.testng.ITestResult; /**
* 监听*/ //所有监听的方法都由接口提供,所以我们需要先实现接口
public class CustomerListeners2 implements ITestListener{ @Override
public void onTestStart(ITestResult result) {
// 测试方法开始时才执行此方法(带@test注解的方法)
// .getName()返回的是测试方法的名称
System.out.println("onTestStart -> test name:"+result.getName());
} @Override
public void onTestSuccess(ITestResult result) {
// 只有在测试方法运行成功后才执行(带@test注解的方法)
System.out.println("onTestSuccess -> test name:"+result.getName());
} @Override
public void onTestFailure(ITestResult result) {
// 只有在测试方法运行失败后才执行(带@test注解的方法)
System.out.println("onTestSuccess -> test name:"+result.getName());
} @Override
public void onTestSkipped(ITestResult result) {
// 在跳过测试时执行
} @Override
public void onTestFailedButWithinSuccessPercentage(ITestResult result) {
// 测试失败但在成功百分比内才执行(自动化中不常用)
} @Override
public void onStart(ITestContext context) {
// 在xml配置文件的test标签中内容运行前执行
// .getName()返回的是标签的名称
System.out.println("onStart -> test tag name:"+context.getName());
// 返回所有测试方法的名字
ITestNGMethod methods[] = context.getAllTestMethods();
System.out.println("test标签中要执行的测试方法:");
for(ITestNGMethod method:methods) {
System.out.println(method.getMethodName());
}
} @Override
public void onFinish(ITestContext context) {
// 在xml配置文件中的test标签运行结束后执行
System.out.println("onFinish -> test tag name:"+context.getName());
}
}
2、被监听类
package testclasses1; import org.testng.Assert;
import org.testng.annotations.AfterClass;
import org.testng.annotations.BeforeClass;
import org.testng.annotations.Listeners;
import org.testng.annotations.Test; import listenerspackage.CustomerListeners1; //表示该测试类被CustomerListeners1类监听
@Listeners(CustomerListeners1.class)
public class TestNG_ListenersTest2 { @BeforeClass
public void setUp() {
System.out.println("Code in before class");
} @AfterClass
public void classUp() {
System.out.println("Code in after class");
} @Test
public void testMethod1() {
System.out.println("Code in testMethod1");
Assert.assertTrue(true);
} @Test
public void testMethod2() {
System.out.println("Code in testMethod2");
Assert.assertTrue(false);
}
}
3、xml配置
<!-- 没有此行配置运行时可能会报错 -->
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name="Listeners TestSuite">
<test name="Application Test">
<classes>
<class name="testclasses1.TestNG_ListenersTest2"></class>
</classes>
</test>
<test name="Application Test">
<classes>
<class name="testclasses1.TestNG_ListenersTest2"></class>
</classes>
</suite>
4、运行结果
三、 ISuiteListener
package listenerspackage; import org.testng.IInvokedMethod;
import org.testng.IInvokedMethodListener;
import org.testng.ISuite;
import org.testng.ISuiteListener;
import org.testng.ITestResult; /**
* 监听*/ //所有监听的方法都由接口提供,所以我们需要先实现接口
public class CustomerListeners3 implements ISuiteListener{ // 当xml文件中suite标签中内容开始执行前
@Override
public void onStart(ISuite suite) {
System.out.println("onStart suite 开始执行之前");
} // 当xml文件中suite标签中内容执行结束后
@Override
public void onFinish(ISuite suite) {
System.out.println("onFinish suite 执行结束之后");
}
}
四、当我们将监听的接口通过类实现后,如果要引用到测试类中,有两种方法:
1、需要使用注解:@Listeners(实现监听接口的类名.class)
2、在xml配置文件中进行配置
<!-- 没有此行配置运行时可能会报错 -->
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name="Listeners TestSuite">
4 <!-- 指定CustomerListeners3方法监听suite中所引用的类,格式:包名.类名 -->
5 <listeners>
6 <listener class-name="listenerspackage.CustomerListeners3"></listener>
7 </listeners>
<test name="Application Test1">
<classes>
<class name="testclasses1.TestNG_ListenersTest1"></class>
</classes>
</test>
<test name="Application Test2">
<classes>
<class name="testclasses1.TestNG_ListenersTest2"></class>
</classes>
</test>
</suite>
如果有不明白的小伙伴可以加群“555191854”问我,群里都是软件行业的小伙伴相互一起学习。
内容具有连惯性,未标注的地方可以看前面的博客,这是一整套关于ava+selenium自动化的内容,从java基础开始。
欢迎关注,转载请注明来源。
章节十六、9-Listeners监听器的更多相关文章
- 章节十六、3-TestNG方法和类注解
一.Test Suite(测试套件) 我们通常认为一个testcase就是一个测试方法,但是会有很多的testcase,所以我们不可能把所有的testcase放到同一个测试类中,假如需要测试的页面有1 ...
- 章节十六、8-ITestResult接口
一.ITestResult:该接口就像一个监听器,能够监听每个方法执行后的状态(是否成功)并将结果返回给我们. package testclasses1; import org.testng.anno ...
- 章节十六、1-TestNG简介
一.TestNG 介绍 1.TestNG 是一个来自 JUnit 和 NUnit 的测试框架,它具拥有更多的功能,提高了 执行的效率. 2.TestNG 是一个开源的自动化测试框架 去除了老框架的大部 ...
- 章节十六、2-TestNG注解和断言
一.TestNG注解的testcease不是自上而下运行的,而是按照方法名的字母排序或数字的大小顺序运行的. 二.断言:判断返回的结果与我们的预期结果是否一致. 1.Assert.assertTrue ...
- 章节十六、4-TestNG高级功能--把测试方法分优先级、分组执行
一. 把测试方法分优先级执行----->(priority=索引) 1.新建一个testng方法 package testclasses; import org.testng.annotatio ...
- 章节十六、5-TestNG高级功能--Part2
一.测试用例的依赖关系--->(dependsOnMethods = {"依赖方法名"}) 1.在实现自动化的过程中,有些测试用例必须在其它测试用例执行之后才能运行,两者之间 ...
- 章节十六、6-xml参数化and并行case
一.读取xml文件中参数 1.案例演示--->创建一个需要读取数据的类 package testclasses; import org.testng.annotations.Test; impo ...
- 章节十六、7-DataProviders
一.当我们的同一个test有多套数据需要进行测试,那么我们就需要用到-->DataProviders package testclasses1; import org.testng.annota ...
- 章节十六、10-TestNG报告和日志
一.在进行自动化的过程中,日志一般采用log4j 2进行日志记录,但TestNG自己本身也带有日志记录功能(reporter),它的好处在于日志中记录的内容都是testng自动生成的. package ...
随机推荐
- Android lifecycle 使用详解
版权声明:本文为博主原创文章,遵循CC 4.0 by-sa版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/gdutxiaoxu/article/det ...
- MongoDB的一些高级语法.md
MongoDB的一些高级语法 AND 和 OR操作 AND操作 OR操作 嵌入式文档 插入 查询 数组(Array)字段 插入 查询 聚合(Aggregation) 筛选数据 修改字段 注意事项 ...
- Python学习 之 计算机基础
第一章 计算机基础 1.1 硬件 计算机基本的硬件由:CPU / 内存 / 主板 / 硬盘 / 网卡 / 显卡 等组成,只有硬件但硬件之间无法进行交流和通信 1.2 操作系统 操作系统用于协同或控制硬 ...
- Mysql主从复制原理及搭建
## Mysql主从复制原理 主从复制是指一台服务器充当主数据库服务器,另一台或多台服务器充当从数据库服务器,主服务器中的数据自动复制到从服务器之中.对于多级复制,数据库服务器即可充当主机,也可充当从 ...
- c++json构建与解析组件 RapidJSON 没用过永远不会知道有多好用
参考资料: 官方文档 推荐[腾讯RapidJSON]学习笔记 原理请参考以上资料 构建json Document doc; Document::AllocatorType &allocator ...
- Windows Server 2008 R2
Windows Server 2008 R2 Windows Server Core 微软因为向往 Linux 的纯命令行, 提出了 Windows Server Core 只能使用命令, 但是只要配 ...
- NLP(十六) DL在NLP中的应用
深度学习中的核心主题是卷积神经网络(CNN)和循环神经网络(RNN) 卷积神经网络 CNN用于图像处理 卷积: 原始图像 5×5 滤波器 3×3 滤波器以步长大于小于1,到处平移,并与原始图像里的3× ...
- HDU-3507Print Article 斜率优化DP
学习:https://blog.csdn.net/bill_yang_2016/article/details/54667902 HDU-3507 题意:有若干个单词,每个单词有一个费用,连续的单词组 ...
- Leetcode337. 打家劫舍 III
Leetcode 337. 打家劫舍 III 在上次打劫完一条街道之后和一圈房屋后,小偷又发现了一个新的可行窃的地区.这个地区只有一个入口,我们称之为"根". 除了"根& ...
- HDU 6346 整数规划 二分图匹配最优解
整数规划 原来的km+hunger跑法T了, 拿了一个新的板子, 新的写法是将这原来的找新的最小的d放在了上一次的残留图上,从而减小复杂度, 但是个人还不是很理解为什么最小的d下一次出现的位置一定是这 ...