Как запустить блок кода после каждого @test, независимо от того, является ли тест @Disabled или нет? - PullRequest
1 голос
/ 28 мая 2019

По сути, я хотел бы добавить запись в свой отчет об экстентах для «Пропущенных тестов».Я понимаю, что могу использовать @AfterEach, однако вижу, что кодовый блок @AfterEach не выполняется для теста @Disabled в Junit5.

Я попытался использовать интерфейс TestWatcher и переопределил метод testDisabled, как показано ниже:

package utils;

import java.util.Optional;

import org.junit.jupiter.api.extension.ExtensionContext;
import org.junit.jupiter.api.extension.TestWatcher;


public class MyTestWatcher implements TestWatcher {
                public static String testStatus;
                public static String testCaseName;
    @Override
    public void testAborted(ExtensionContext Context, Throwable throwable) {
                testStatus = "Aborted";
                testCaseName = Context.getDisplayName();
                System.out.println("Test Aborted: " + Context.getDisplayName());
                }

    @Override
    public void testDisabled(ExtensionContext Context, Optional<String> optional) {
                testStatus = "Skipped";
                testCaseName = Context.getDisplayName();  
                System.out.println("Test Skipped: " + Context.getDisplayName());
                }

    @Override
    public void testFailed(ExtensionContext Context, Throwable throwable) {
                testStatus = "Failed";
                testCaseName = Context.getDisplayName();   
               System.out.println("Test Failed: " + Context.getDisplayName());
}

    @Override
    public void testSuccessful(ExtensionContext Context) {
                testStatus = "Passed";
                testCaseName = Context.getDisplayName();
                System.out.println("Test Passed: " + Context.getDisplayName());
    }

}

На основе переменных 'testStatus' и 'testCaseName', которые установлены в методе testDisabled () вышеЯ хотел бы запустить блок кода из моего тестового класса, чтобы добавить запись в мой отчет по экстентам, в которой указано, какой тестовый пример был пропущен.

Ответы [ 2 ]

1 голос
/ 28 мая 2019

Если я правильно понял ваш вопрос, вам просто нужно применить TestWatcher к тесту, чтобы решить вашу проблему.С JUnit 5 вы можете использовать @ExtendsWith аннотацию .Полный пример будет:

@ExtendWith(MyTestWatcher.class)
class MyTest {

  @Test
  void test() {
    System.out.println("inside active test");
  }

  @Test
  @Disabled
  void testDisabled() {
    System.out.println("inside disabled test");
  }

}

С выводом:

inside active test
Test Passed: test()
Test Skipped: testDisabled()

Протестировано с JUnit 5.4.2

0 голосов
/ 29 мая 2019

Мне удалось добавить отчеты для пропущенных тестов, инициализировав отчет по экстентам из класса MyTestWatcher. Несмотря на то, что объект ExtentReport уже был инициализирован в моем тестовом классе, когда я снова попытаюсь инициализировать (что приведет к созданию еще одного отчета в виде файла HTML), я добавил приведенный ниже код в свой класс ExtentManager:

public static ExtentReports GetExtent(String env){
        **if (extent != null)
          return extent; //avoid creating new instance of html file**
        extent = new ExtentReports();       
        extent.attachReporter(getHtmlReporter());
        extent.setSystemInfo("Environment",env);
        extent.setAnalysisStrategy(AnalysisStrategy.SUITE);
        return extent;

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

package utils;

import java.util.Optional;

import org.junit.jupiter.api.extension.ExtensionContext;
import org.junit.jupiter.api.extension.TestWatcher;

import com.aventstack.extentreports.ExtentReports;
import com.aventstack.extentreports.ExtentTest;
import com.aventstack.extentreports.Status;




public class MyTestWatcher implements TestWatcher {
                public static String testCaseName;
                public static ExtentReports extent;
                public static ExtentTest report;

    static 
                {
                extent = utils.ExtentReportManager.GetExtent(System.getProperty("env"));
                report = extent.createTest("Skipped Tests", "Tests which are skipped are displayed here.");
                }
    @Override
    public void testAborted(ExtensionContext Context, Throwable throwable) {
                testCaseName = Context.getDisplayName();
                System.out.println("Test Aborted: " + Context.getDisplayName());
                }

    @Override
    public void testDisabled(ExtensionContext Context, Optional<String> optional) {
                testCaseName = Context.getDisplayName();  
                System.out.println("Test Skipped: " + Context.getDisplayName());
                report.createNode(testCaseName).log(Status.SKIP, "This test is marked as @DISABLED");
                }

    @Override
    public void testFailed(ExtensionContext Context, Throwable throwable) {
                testCaseName = Context.getDisplayName();   
               System.out.println("Test Failed: " + Context.getDisplayName());
                }

    @Override
    public void testSuccessful(ExtensionContext Context) {
                testCaseName = Context.getDisplayName();
                System.out.println("Test Passed: " + Context.getDisplayName());
    }

}
...