繁体   English   中英

“ org.testng.TestNGException:org.xml.sax.SAXParseException; 在侦听器上工作时,必须声明元素类型“侦听器”

[英]“org.testng.TestNGException: org.xml.sax.SAXParseException; Element type ”Listeners" must be declared. while working on listeners

我正在使用TestNG侦听器来生成范围报告,然后出现以下异常。

org.testng.TestNGException:org.xml.sax.SAXParseException; lineNumber:4; columnNumber:12; 元素类型“ Listeners”必须声明。

使用ITestListener时观察到的问题相同。 因此,问题可能完全出在监听器上。 请在这方面帮助我。

我的测试环境如下所述。 selenium-java:版本-3.141.59 testng:版本-6.14.3 Java:版本-1.8

我尝试过添加com.aventstack的最新或较旧版本的ExtentReport依赖项以及旧的com.relevantcodes版本,如下所示

com.aventstack扩展报告4.0.9或3.1.5以及com.relevantcodes扩展报告2.41.2或2.41.1

我也尝试过在Testng.xml或实现该侦听器的类中或同时在这两者中提供侦听器信息

1. Testng.xml文件“ />”或2.在实现Listener @Listeners({。class})的类中直接使用@Listeners批注

请找到如下代码

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 -->

记者

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();
    }

}

问题出在您的套件xml文件中。

在套件xml文件中定义侦听器的正确方法是使用标签<listeners></listeners> 您的套件xml分别将它们定义为<Listeners></Listeners><Listener> 请修正您的标签,使其在所有小写情况下均已定义。

您的标签以大写字母开头。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM