Получение ошибки cucumber.runtime.CucumberException: не удалось загрузить класс плагина: com.cucumber.listener.ExtentCucumberFormatter.

Я пытаюсь создать отчет об экстенте для своего тестового прогона с использованием огурца Junit, но получаю сообщение об ошибке

"cucumber.runtime.CucumberException: Couldn't load plugin class: com.cucumber.listener.ExtentCucumberFormatter. It does not implement cucumber.api.Plugin "

Моя трассировка ошибок выглядит следующим образом:

cucumber.runtime.CucumberException: Couldn't load plugin class: com.cucumber.listener.ExtentCucumberFormatter. It does not implement cucumber.api.Plugin
    at cucumber.runtime.formatter.PluginFactory.loadClass(PluginFactory.java:179)
    at cucumber.runtime.formatter.PluginFactory.pluginClass(PluginFactory.java:166)
    at cucumber.runtime.formatter.PluginFactory.getPluginClass(PluginFactory.java:223)
    at cucumber.runtime.formatter.PluginFactory.isFormatterName(PluginFactory.java:201)
    at cucumber.runtime.RuntimeOptionsFactory.addPlugins(RuntimeOptionsFactory.java:94)
    at cucumber.runtime.RuntimeOptionsFactory.buildArgsFromOptions(RuntimeOptionsFactory.java:41)
    at cucumber.runtime.RuntimeOptionsFactory.create(RuntimeOptionsFactory.java:26)
    at cucumber.api.junit.Cucumber.<init>(Cucumber.java:74)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
    at org.junit.internal.builders.AnnotatedBuilder.buildRunner(AnnotatedBuilder.java:104)
    at org.junit.internal.builders.AnnotatedBuilder.runnerForClass(AnnotatedBuilder.java:86)
    at org.junit.runners.model.RunnerBuilder.safeRunnerForClass(RunnerBuilder.java:59)
    at org.junit.internal.builders.AllDefaultPossibilitiesBuilder.runnerForClass(AllDefaultPossibilitiesBuilder.java:26)
    at org.junit.runners.model.RunnerBuilder.safeRunnerForClass(RunnerBuilder.java:59)
    at org.junit.internal.requests.ClassRequest.getRunner(ClassRequest.java:33)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.createUnfilteredTest(JUnit4TestLoader.java:87)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.createTest(JUnit4TestLoader.java:73)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.loadTests(JUnit4TestLoader.java:46)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:522)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:760)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:460)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:206)

Мой Pom.xml имеет следующие зависимости:

<dependency>
            <groupId>io.cucumber</groupId>
            <artifactId>cucumber-java</artifactId>
            <version>2.3.1</version>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>


        <dependency>
            <groupId>io.cucumber</groupId>
            <artifactId>cucumber-testng</artifactId>
            <version>2.3.1</version>
        </dependency>

        <dependency>
            <groupId>com.beust</groupId>
            <artifactId>jcommander</artifactId>
            <version>1.27</version>
        </dependency>

        <dependency>
            <groupId>io.cucumber</groupId>
            <artifactId>cucumber-junit</artifactId>
            <version>2.3.1</version>
            <scope>test</scope>
        </dependency>



        <dependency>
            <groupId>org.testng</groupId>
            <artifactId>testng</artifactId>
            <version>6.13</version>
            <scope>test</scope>
        </dependency>

        <dependency> <groupId>org.seleniumhq.selenium</groupId> <artifactId>selenium-java</artifactId> 
            <version>3.8.1</version> </dependency> 

        <dependency>
            <groupId>com.vimalselvam</groupId>
            <artifactId>cucumber-extentsreport</artifactId>
            <version>3.0.0</version>
        </dependency>




        <dependency>
            <groupId>com.aventstack</groupId>
            <artifactId>extentreports</artifactId>
            <version>3.1.3</version>
        </dependency>


        <dependency>
            <groupId>com.relevantcodes</groupId>
            <artifactId>extentreports</artifactId>
            <version>2.41.2</version>
        </dependency>


        <dependency>
            <groupId>info.cukes</groupId>
            <artifactId>cucumber-jvm-deps</artifactId>
            <version>1.0.3</version>
            <scope>provided</scope>
        </dependency>


        <dependency>
            <groupId>info.cukes</groupId>
            <artifactId>gherkin</artifactId>
            <version>2.7.3</version>
        </dependency>

Мой класс Runner выглядит следующим образом:

package com.cumberpr2.Runner;

import java.io.File;

import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.runner.RunWith;

import com.cucumber.listener.ExtentProperties;
import com.cucumber.listener.Reporter;

import cucumber.api.CucumberOptions;
import cucumber.api.junit.Cucumber;

@RunWith(Cucumber.class)
@CucumberOptions(features= {"src/test/java/com/cumberpr2/First/feature"},glue= {"com/cumberpr2/step"},
monochrome=true,tags= {"@bvt,@sanity"},plugin={"com.cucumber.listener.ExtentCucumberFormatter:target/cucumber/report1.html"} 
)
//{"pretty","html:target/cucumber","com.cucumber.listener.ExtentCucumberFormatter"}
public class Runner1 {

     @AfterClass
        public static void teardown() {
            Reporter.loadXMLConfig(new File("/src/test/java/com/cumberpr2/step/Extent-Config.xml"));

            Reporter.setSystemInfo("os", "windows OSX");
            Reporter.setTestRunnerOutput("Sample test runner output message");
        }

    /* @BeforeClass
     public static void setup() {
         ExtentProperties extentProperties = ExtentProperties.INSTANCE;
         extentProperties.setReportPath("output/myreport.html");
         extentProperties.setExtentXServerUrl("http://localhost:1337");
         extentProperties.setProjectName("MyProject");
     }*/


}

Структура моей папки выглядит следующим образом: [1]: https://i.stack.imgur.com/ek06R.png

[введите описание изображения здесь][1]


person vikramaditya anand    schedule 11.03.2018    source источник
comment
Кажется, это известная проблема. Отчет об экстенте пока не поддерживает огурец 2. github.com/email2vimalraj/CucumberExtentReporter/issues/75   -  person Grasshopper    schedule 11.03.2018
comment
@Кузнечик спасибо   -  person vikramaditya anand    schedule 18.03.2018


Ответы (2)


После многих дней поиска решения этой проблемы, которая также случалась со мной, я обнаружил причину (по крайней мере, это сработало для меня). Судя по всему, плагин com.cucumber.listener.ExtentCucumberFormatter или com.vimalselvam.cucumber.listener.ExtentCucumberFormatter (для cucumber-extentreports версии 3.1.1+) работает только с огурцом из пакета info.cukes.

<! - https://mvnrepository.com/artifact/info.cukes/cucumber-java ->
<dependency>
<groupId>info.cukes</ groupId>
<artifactId>cucumber-java</artifactId>    
<version>1.2.5</ version>
</dependency>

Чтобы использовать ExtentReports с самыми последними версиями огурца (пакет io.cucumber, начиная с версии 2.X.X и выше), вам необходимо добавить плагин огурца-адаптера.

Для каждой версии X огурца существует адаптер, например, для версии огурца 4.X.X требуется зависимость extensions-cucumber4-adapter.

<dependency>
<groupId>com.aventstack</groupId>
<artifactId>extentreports-cucumber4-adapter</artifactId>
<version>1.0.7</version>
</dependency>

          

А в классе Runner следует заменить плагин:

"com.cucumber.listener.ExtentCucumberFormatter:"

by

"com.aventstack.extentreports.cucumber.adapter.ExtentCucumberAdapter:"

Для примера использования огурца 4 с отчетами об экстентах перейдите по ссылке GitHub, которую я нашел:

https://github.com/foursyth/extentreports-cucumber4-example

Для версий 2.X.X и 3.X.X действуют те же принципы, что и для 4.X.X.

Ссылка на спецификацию настроек ExtentReport всех версий:

http://extentreports.com/documentation/

Надеюсь это поможет.

person João Rener    schedule 13.05.2019

Советуем обновить cucumber v до версии 4.x.x. Это не только устранит вашу ошибку, но и позволит создать сводный отчет во время параллельного выполнения, а также без создания бегунов. вручную.

Есть 2 способа реализации отчета об экстенте в Cucumber:

<сильный>1. Использование адаптера Cucumber-JVM 4 для Extent Framework (extentreports-cucumber4-adapter). Прелесть в том, что вам не нужно писать какой-либо код где-либо, чтобы создать отчет таким образом, за исключением настройки адаптера в бегуне ниже.

Добавить зависимость адаптера в POM.XML

<dependency>
    <groupId>com.aventstack</groupId>
    <artifactId>extentreports-cucumber4-adapter</artifactId>
    <version>1.0.6</version>
</dependency>

Добавьте подключаемый модуль com.aventstack.extentreports.cucumber.adapter.ExtentCucumberAdapter в средство выполнения.

@RunWith(Cucumber.class)
@CucumberOptions(plugin = {"com.aventstack.extentreports.cucumber.adapter.ExtentCucumberAdapter:"})
public class RunCukesTest {
    // ..
} 

Каталог вывода отчета — ../Project Directory/test-output/HtmlReport

<сильный>2. Добавление зависимости aventstack в POM.XML

<dependency>
    <groupId>com.aventstack</groupId>
    <artifactId>extentreports</artifactId>
    <version>3.1.5</version>
</dependency> 

В этом рабочем процессе Не добавляйте подключаемый модуль com.aventstack.extentreports.cucumber.adapter.ExtentCucumberAdapter в средство выполнения.

person TheSociety    schedule 13.05.2019