TestListenerAdapter,空方法实现 ITestListener
创建自定义日志记录类
创建另一个新的类名为 CustomListener.java 在 C:\ > TestNG_WORKSPACE
import org.testng.ITestResult; import org.testng.TestListenerAdapter; public class CustomListener extends TestListenerAdapter{ private int m_count = 0; @Override public void onTestFailure(ITestResult tr) { log(tr.getName()+ "--Test method failed\n"); } @Override public void onTestSkipped(ITestResult tr) { log(tr.getName()+ "--Test method skipped\n"); } @Override public void onTestSuccess(ITestResult tr) { log(tr.getName()+ "--Test method success\n"); } private void log(String string) { System.out.print(string); if (++m_count % 40 == 0) { System.out.println(""); } } }
创建测试案例类
创建一个Java类为 SampleTest.java 在 C:\ > TestNG_WORKSPACE
import org.testng.Assert; import org.testng.annotations.Test; public class SampleTest { @Test public void testMethodOne(){ Assert.assertTrue(true); } @Test public void testMethodTwo(){ Assert.assertTrue(false); } @Test(dependsOnMethods={"testMethodTwo"}) public void testMethodThree(){ Assert.assertTrue(true); } }
前面的测试类包含三种测试方法,其中testMethodOne andtestMethodThree将通过执行时,
而testMethodTwo是通过一个falseBoolean值断言失败。 assertTrue方法,该方法用于在测试中的真值条件。
创建 testng.xml
创建一个文件 testng.xml C:\ > TestNG_WORKSPACE 来执行测试用例
<?xml version="1.0" encoding="UTF-8"?> <suite name="Simple Logger Suite"> <listeners> <listener class-name="CustomListener" /> </listeners> <test name="Simple Logger test"> <classes> <class name="SampleTest" /> </classes> </test> </suite>
编译SampleTest,CustomListener类使用javac
C:\TestNG_WORKSPACE>javac CustomListener.java SampleTest.java
现在运行 testng.xml.
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
验证输出
testMethodOne--Test method success testMethodTwo--Test method failed testMethodThree--Test method skipped =============================================== Simple Logger Suite Total tests run: 3, Failures: 1, Skips: 1 ===============================================
我们创建了一个自定义logger类,其中实现ITestListener接口和依附于作为监听器的TestNG测试套件。
TestNG的测试开始时,测试失败,在测试成功,所以这个监听器类的方法调用。
可以实现多个听众,并将其添加到测试套件执行,TestNG的将调用所有侦听器连接到测试套件。
当我们需要看到的连续状态的测试执行,测试时得到执行,主要用于记录监听器。