testng监听器,实际上就是一些预定义的 Java 接口。用户创建这些接口的实现类,并把它们加入到 TestNG 中,TestNG 便会在测试运行的不同时刻调用这些类中的接口方法。
本篇介绍监听器ITestLisntener:该监听器的作用是,用来指定在测试方法执行成功、失败或者跳过时的不同后续行为,以下主要实现对3种测试结果的打印提示。
ITestListener 监听器要求实现的方法中包含如下三个
void onTestFailure(ITestResult result)
void onTestSkipped(ITestResult result)
void onTestSuccess(ITestResult result)
测试案例:
1.在testng.xml里加上listeners标签:
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" > <suite name="suite1"> <listeners> <listener class-name="listeners.myListener" /> </listeners> <test name="test" preserve-order="true" verbose="0"> <parameter name="url" value="http://123.57.56.45:7778/test/initLogin" /> <parameter name="username" value="999111" /> <parameter name="password" value="111111" /> <classes > <class name="com.test.testng" > <methods> <include name="Login" /> </methods> </class> </classes> </test> </suite>
2.在脚本文件中添加@Listeners标签(步骤1和2两种只需要设置一个即可,否则运行后会看到重复的测试结果输出)
部分脚本如下:
@Listeners({ myListener.class }) public class test{ LoginAction login = null; WebDriver webdriver = new FirefoxDriver(); @Parameters({"url"}) @BeforeTest public void beforeMethod(String url) { // 初始化类,并打开链接 login = new LoginAction(webdriver); webdriver.get(url); webdriver.manage().window().maximize(); } @Parameters({"username", "password" }) @Test(priority = 0) public void Login(String username,String password) { // 登录 login.Login(username, password); }
3.myListener.class代码如下:
myListener.class代码如下:
package listeners; import org.testng.ITestResult; import org.testng.TestListenerAdapter; public class myListener extends TestListenerAdapter{ @Override // @Override是伪代码,表示重写(当然不写也可以) public void onTestFailure(ITestResult tr) { log(tr.getName()+ "--执行失败\n"); } @Override public void onTestSkipped(ITestResult tr) { log(tr.getName()+ "--执行跳过\n"); } @Override public void onTestSuccess(ITestResult tr) { log(tr.getName()+ "--执行成功\n"); } private void log(String string) { System.out.print(string); } }
4.右键选择testng.xml,run as-testng suite,执行结果:
Login--执行成功