Я работаю над прослушивателем TestNG, чтобы сгенерировать отчет по экстентам, а затем получаю следующее исключение:
org.testng.TestNGException: org.xml.sax.SAXParseException;номер строки: 4;номер столбца: 12;Тип элемента "Listeners" должен быть объявлен.
Такая же проблема наблюдается при работе с ITestListener.Таким образом, проблема может быть полностью со Слушателями.Пожалуйста, помогите мне в этом.
Моя тестовая среда, как указано ниже.selenium-java: версия- 3.141.59 testng: версия- 6.14.3 Java: версия- 1.8
Я попытался добавить зависимости ExtentReport либо в последнюю, либо в более старые версии из com.aventstack вместе со старым comВерсии .relevantcodes, как показано ниже
com.aventstack extremereports 4.0.9 ИЛИ 3.1.5 вместе с com.relevantcodes extenreports 2.41.2 ИЛИ 2.41.1
У меня также естьпопытался предоставить информацию о слушателе либо в Testng.xml, либо в классе, реализующем слушателя, либо в обоих
1.Файл testng.xml "/> или 2. Непосредственно с помощью аннотации @Listeners в классе, который реализует Listener @Listeners ({. Class})
Пожалуйста, найдите код, как показано ниже
файл 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/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>Framework</groupId>
<artifactId>Jesus_Practise</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>Jesus_Practise</name>
<url>http://maven.apache.org</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>org.seleniumhq.selenium</groupId>
<artifactId>selenium-java</artifactId>
<version>3.141.59</version>
</dependency>
<dependency>
<groupId>org.testng</groupId>
<artifactId>testng</artifactId>
<version>6.14.3</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>com.relevantcodes</groupId>
<artifactId>extentreports</artifactId>
<version>2.41.1</version>
</dependency>
<dependency>
<groupId>com.aventstack</groupId>
<artifactId>extentreports</artifactId>
<version>3.1.5</version>
</dependency>
</dependencies>
</project>
файл testng.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd">
<suite name="FreeCRM Test Suite">
<Listeners>
<Listener class-name="com.qa.Listeners.ExtentReporterNG"/>
<Listener class-name="com.qa.Listeners.ITestListen"/>
</Listeners>
<test thread-count="5" name="FreeCRM Test">
<classes>
<class name="com.qa.testcases.LoginPageTest" />
</classes>
</test> <!-- Test -->
</suite> <!-- Suite -->
Reporter
package com.qa.Listeners;
import java.io.File;
import java.util.Calendar;
import java.util.Date;
import java.util.List;
import java.util.Map;
import org.testng.IReporter;
import org.testng.IResultMap;
import org.testng.ISuite;
import org.testng.ISuiteResult;
import org.testng.ITestContext;
import org.testng.ITestResult;
import org.testng.annotations.Listeners;
import org.testng.xml.XmlSuite;
import com.relevantcodes.extentreports.ExtentReports;
import com.relevantcodes.extentreports.ExtentTest;
import com.relevantcodes.extentreports.LogStatus;
@Listeners({ExtentReporterNG.class})
public class ExtentReporterNG implements IReporter{
private ExtentReports extent;
public void generateReport(List<XmlSuite> xmlSuites, List<ISuite> suites,
String outputDirectory) {
extent = new ExtentReports(outputDirectory + File.separator
+ "Extent.html", true);
for (ISuite suite : suites) {
Map<String, ISuiteResult> result = suite.getResults();
for (ISuiteResult r : result.values()) {
ITestContext context = r.getTestContext();
buildTestNodes(context.getPassedTests(), LogStatus.PASS);
buildTestNodes(context.getFailedTests(), LogStatus.FAIL);
buildTestNodes(context.getSkippedTests(), LogStatus.SKIP);
}
}
extent.flush();
extent.close();
}
private void buildTestNodes(IResultMap tests, LogStatus status) {
ExtentTest test;
if (tests.size() > 0) {
for (ITestResult result : tests.getAllResults()) {
test = extent.startTest(result.getMethod().getMethodName());
test.setStartedTime(getTime(result.getStartMillis()));
test.setEndedTime(getTime(result.getEndMillis()));
for (String group : result.getMethod().getGroups())
test.assignCategory(group);
if (result.getThrowable() != null) {
test.log(status, result.getThrowable());
} else {
test.log(status, "Test " + status.toString().toLowerCase()
+ "ed");
}
extent.endTest(test);
}
}
}
private Date getTime(long millis) {
Calendar calendar = Calendar.getInstance();
calendar.setTimeInMillis(millis);
return calendar.getTime();
}
}