如何在 @AfterMethod 中获取 TestNG 的结果状态?
TestNG 支持原生依赖注入。它允许在方法中声明附加参数。在运行时,TestNG 会自动使用正确的值填充这些参数。以下是 TestNG 中一些原生依赖项的列表
ITestContext
XmlTest
Method
ITestResult
您可以使用这些依赖项来获取 TestNG 中测试的执行状态。
通常,@AfterMethod 支持所有这些原生依赖项,测试状态可以是成功、失败或跳过。
TestNG 支持以下测试状态,可以通过在正确的位置调用函数来检索。
| org.testng.ITestResult | ||
|---|---|---|
| public static final int | FAILURE (失败) | 2 |
| public static final int | SKIP (跳过) | 3 |
| public static final int | STARTED (已开始) | 16 |
| public static final int | SUCCESS (成功) | 1 |
| public static final int | SUCCESS_PERCENTAGE_FAILURE (成功率失败) | 4 |
在这篇文章中,我们将使用ITestResult 依赖项来展示如何在 TestNG 中检索测试的结果状态。
假设用户想要在执行后检索测试方法的状态。在这种情况下,代码将写在 @AfterMethod 内以检索测试方法状态。
由于 @AfterMethod 在每次 @Test 方法之后执行,我们将显示每个测试已执行的测试方法名称的状态。在这里,我们将使用getStatus() 方法,它将返回一个整数,如上表所示。用户应该使用这些状态代码作为整数来实现字符串。
解决此问题的方法/算法:
步骤 1 - 创建一个名为NewTestngClass 的 TestNG 类并编写@AfterMethod 方法。
步骤 2 - 在类中编写 3 个不同的 @Test 方法,一个用于成功,一个用于失败,一个用于跳过,如程序代码所示。
步骤 3 - 现在创建如下所示的 testNG.xml 来运行 TestNG 类。
步骤 4 - 运行 testNG.xml 或直接在 IDE 中运行 TestNG 类,或者使用命令行进行编译和运行。
示例
使用以下代码作为通用的 TestNG 类“NewTestngClass”:
src/ NewTestngClass.java
import org.testng.ITestResult;
import org.testng.SkipException;
import org.testng.annotations.*;
public class NewTestngClass {
@Test()
public void testcase1(){
System.out.println("TestCase 1 - Execution started");
assert true;
}
@Test()
public void testcase2(){
System.out.println("TestCase 2 - Execution started");
assert false;
}
@Test()
public void testcase3(){
System.out.println("TestCase 3 - Execution started");
throw new SkipException("Skipping the testcase 3");
}
@AfterMethod()
public void status(ITestResult result){
System.out.println("Status of execution is:"+result.getStatus());
try{
if(result.getStatus() == ITestResult.SUCCESS){
System.out.println("Test case execution status is SUCCESS");
}
else if(result.getStatus() == ITestResult.FAILURE){
// Do something here
System.out.println("Test case execution status is FAILURE");
}
else if(result.getStatus() == ITestResult.SKIP ){
System.out.println("Test case execution status is SKIP");
}
}
catch(Exception e){
e.printStackTrace();
}
}
}testNG.xml
这是一个用于组织和运行 TestNG 测试用例的配置文件。当只需要执行有限的测试而不是完整的套件时,它非常方便。
<?xml version = "1.0" encoding = "UTF-8"?> <!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" > <suite name = "Suite1"> <test name = "test1"> <classes> <class name = "NewTestngClass"/> </classes> </test> </suite>
输出
TestCase 1 - Execution started Status of execution is:1 Test case execution status is SUCCESS TestCase 2 - Execution started java.lang.AssertionError at NewTestngClass.testcase2(NewTestngClass.java:15) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498) at org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:133) at org.testng.internal.TestInvoker.invokeMethod(TestInvoker.java:598) at org.testng.internal.TestInvoker.invokeTestMethod(TestInvoker.java:173) at org.testng.internal.MethodRunner.runInSequence(MethodRunner.java:46) at org.testng.internal.TestInvoker$MethodInvocationAgent.invoke(TestInvoker.java:824) at org.testng.internal.TestInvoker.invokeTestMethods(TestInvoker.java:146) at org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:146) at org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:128) at java.util.ArrayList.forEach(ArrayList.java:1259) at org.testng.TestRunner.privateRun(TestRunner.java:794) at org.testng.TestRunner.run(TestRunner.java:596) at org.testng.SuiteRunner.runTest(SuiteRunner.java:377) at org.testng.SuiteRunner.runSequentially(SuiteRunner.java:371) at org.testng.SuiteRunner.privateRun(SuiteRunner.java:332) at org.testng.SuiteRunner.run(SuiteRunner.java:276) at org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:53) at org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:96) at org.testng.TestNG.runSuitesSequentially(TestNG.java:1212) at org.testng.TestNG.runSuitesLocally(TestNG.java:1134) at org.testng.TestNG.runSuites(TestNG.java:1063) at org.testng.TestNG.run(TestNG.java:1031) at com.intellij.rt.testng.IDEARemoteTestNG.run(IDEARemoteTestNG.java:66) at com.intellij.rt.testng.RemoteTestNGStarter.main(RemoteTestNGStarter.java:109) Status of execution is:2 Test case execution status is FAILURE TestCase 3 - Execution started Test ignored. Status of execution is:3 Test case execution status is SKIP =============================================== Suite1 Total tests run: 3, Passes: 1, Failures: 1, Skips: 1 ===============================================
数据结构
网络
关系数据库管理系统 (RDBMS)
操作系统
Java
iOS
HTML
CSS
Android
Python
C 语言编程
C++
C#
MongoDB
MySQL
Javascript
PHP