问题描述
java.lang.classCastException 错误与 Listeners/ExtenReporterNG 类有关。我知道是这种情况,因为当我从 TestNG 中删除以下几行时,所有测试用例都会运行而不会出现此错误。
<listeners>
<listener class-name= "resources.ExtentReporterNG"/>
<listener class-name= "Academy.Listeners"/>
</listeners>
我已经用尽了所有方法来处理这样的问题。感谢您的建议。
解决方法
尝试类 ExtentReporterNG 实现 IReporter
,我的范围报告代码是:
package resources;
import com.aventstack.extentreports.ExtentReports;
import com.aventstack.extentreports.reporter.ExtentSparkReporter;
public class ExtentReporterNG {
static ExtentReports extent;
public static ExtentReports getReportObject()
{
String path =System.getProperty("user.dir")+"\\reports\\index.html";
ExtentSparkReporter reporter = new ExtentSparkReporter(path);
reporter.config().setReportName("Web Automation Results");
reporter.config().setDocumentTitle("Test Results");
extent =new ExtentReports();
extent.attachReporter(reporter);
extent.setSystemInfo("Tester","Adam");
return extent;
}
}
======================
我的 Listeners 类代码是:
package Academy;
import java.io.IOException;
import org.openqa.selenium.WebDriver;
import org.testng.ITestContext;
import org.testng.ITestListener;
import org.testng.ITestResult;
import com.aventstack.extentreports.ExtentReports;
import com.aventstack.extentreports.ExtentTest;
import com.aventstack.extentreports.Status;
import resources.ExtentReporterNG;
import resources.base;
public class Listeners extends base implements ITestListener {
ExtentTest test;
ExtentReports extent =ExtentReporterNG.getReportObject(); .
ThreadLocal<ExtentTest> extentTest= new ThreadLocal<ExtentTest>();
@Override
public void onTestStart(ITestResult result) { // for every testcase as the name implies. For reporting.
test= extent.createTest(result.getMethod().getMethodName());
extentTest.set(test);
//ITestListener.super.onTestStart(result);
}
@Override
public void onFinish(ITestContext context) {
extent.flush();
}
@Override
public void onTestSuccess(ITestResult result) {
extentTest.get().log(Status.PASS,"TEST PASSED");
}
@Override
public void onTestFailure(ITestResult result) {
extentTest.get().fail(result.getThrowable());
WebDriver driver=null;
String testMethodName= result.getMethod().getMethodName();
try {
driver =(WebDriver)result.getTestClass().getRealClass().getDeclaredField("driver").get(result.getInstance());
} catch(Exception e)
{
}
try {
extentTest.get().addScreenCaptureFromPath(getScreenShotPath(testMethodName,driver),result.getMethod().getMethodName());
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
========================================
TestNG XML 文件的内容是:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name="Suite">
<listeners>
<listener class-name= "resources.ExtentReporterNG"/>
<listener class-name= "Academy.Listeners"/>
</listeners>
<test thread-count="5" name="Test">
<classes>
<class name="Academy.AmazonTest"/>
</classes>
</test> <!-- Test -->
</suite> <!-- Suite -->
============================ 我的 pom.xml 文件是:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>Academy</groupId>
<artifactId>Project</artifactId>
<version>1.0-SNAPSHOT</version>
<name>Project</name>
<url>http://maven.apache.org</url>
<properties>
<maven.compiler.source>1.7</maven.compiler.source>
<maven.compiler.target>1.7</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<build>
<resources>
<resource>
<directory>src/main/java/resources</directory> <!-- I am telling the maven pom.xml file that there is a log4j2.xml file located under resources which is located under main-->
<filtering>true</filtering>
</resource>
</resources>
</build>
<profiles>
<profile>
<id>regression</id>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>3.0.0-M3</version>
<configuration>
<suiteXmlFiles>
<suiteXmlFile>testng.xml</suiteXmlFile>
</suiteXmlFiles>
</configuration>
</plugin>
</plugins>
</build>
</profile>
<profile>
<id>sanity</id>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>3.0.0-M3</version>
<configuration>
<suiteXmlFiles>
<suiteXmlFile>testng2.xml</suiteXmlFile>
</suiteXmlFiles>
</configuration>
</plugin>
</plugins>
</build>
</profile>
</profiles>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.seleniumhq.selenium</groupId>
<artifactId>selenium-java</artifactId>
<version>3.141.59</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>2.14.1</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>2.14.1</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.testng/testng -->
<dependency>
<groupId>org.testng</groupId>
<artifactId>testng</artifactId>
<version>7.1.0</version>
</dependency>
<!-- https://mvnrepository.com/artifact/com.relevantcodes/extentreports -->
<dependency>
<groupId>com.relevantcodes</groupId>
<artifactId>extentreports</artifactId>
<version>2.41.2</version>
</dependency>
<!--https://mvnrepository.com/artifact/com.aventstack/extentreports -->
<dependency>
<groupId>com.aventstack</groupId>
<artifactId>extentreports</artifactId>
<version>4.1.4</version>
</dependency>
<!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.6</version>
</dependency>
</dependencies>
</project>
,
我已经找到了问题的根本原因:
在 TesNT.XML 文件中,您应该:
<listeners>
<listener class-name= "academy.Listeners"/>
</listeners>
代替
<listeners>
<listener class-name= "resources.ExtentReporterNG"/>
<listener class-name= "Academy.Listeners"/>
</listeners>
原因是,ExtentReporterNG.java 已经集成在 Listeners.java 中