Maven возвращает выход 0, даже если тесты junit5 не пройдены - PullRequest
0 голосов
/ 12 декабря 2018

У меня настроен Maven для запуска некоторых тестов junit5.

Когда я запускаю:

mvn clean integration-test

Я вижу сборку проекта, а затем он также запускает тесты.Я вижу сбой в одном из модульных тестов.

Далее в выводе консоли я вижу:

[INFO] BUILD SUCCESS

Что я делаю не так?Я ожидаю, что неудачный тестовый запуск остановит такой инструмент, как maven, и вернет код выхода 1.

Это особенно расстраивает в CI, потому что кажется, что тесты исправны, поскольку код выхода возвращает ноль.

РЕДАКТИРОВАТЬ: Вот 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>com.github.(removedforstackoverflowpost)</groupId>
    <artifactId>(removedforstackoverflowpost)</artifactId>
    <packaging>jar</packaging>
    <version>0.0.1</version>
    <name>(removedforstackoverflowpost)</name>
    <url>(removedforstackoverflowpost)</url>
    <description>(removedforstackoverflowpost)</description>
    <licenses>
        <license>
            <name>MIT License</name>
            <url>http://www.opensource.org/licenses/mit-license.php</url>
        </license>
    </licenses>
    <developers>
        <developer>
            <name>(removedforstackoverflowpost)</name>
            <email>(removedforstackoverflowpost)</email>
            <organization>(removedforstackoverflowpost)</organization>
            <organizationUrl>(removedforstackoverflowpost)</organizationUrl>
        </developer>
    </developers>
    <scm>
        <connection>(removedforstackoverflowpost)</connection>
        <developerConnection>(removedforstackoverflowpost)</developerConnection>
        <url>(removedforstackoverflowpost)</url>
    </scm>
    <properties>
        <maven.compiler.source>1.6</maven.compiler.source>
        <maven.compiler.target>1.6</maven.compiler.target>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.junit.jupiter</groupId>
            <artifactId>junit-jupiter-api</artifactId>
            <version>5.3.1</version>
        </dependency>
        <dependency>
            <groupId>com.google.code.gson</groupId>
            <artifactId>gson</artifactId>
            <version>2.8.5</version>
        </dependency>
        <dependency>
            <groupId>com.googlecode.json-simple</groupId>
            <artifactId>json-simple</artifactId>
            <version>1.1</version>
        </dependency>
        <dependency>
            <groupId>javassist</groupId>
            <artifactId>javassist</artifactId>
            <version>3.12.1.GA</version>
        </dependency>
        <dependency>
            <groupId>org.junit.platform</groupId>
            <artifactId>junit-platform-console-standalone</artifactId>
            <version>1.3.2</version>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <plugin>
                <artifactId>maven-surefire-plugin</artifactId>
                <!-- latest version (2.20.1) does not work well with JUnit5 -->
                <version>2.19.1</version>
                <dependencies>
                    <dependency>
                        <groupId>org.junit.platform</groupId>
                        <artifactId>junit-platform-surefire-provider</artifactId>
                        <version>1.0.3</version>
                    </dependency>
                    <dependency>
                        <groupId>org.junit.jupiter</groupId>
                        <artifactId>junit-jupiter-engine</artifactId>
                        <version>5.0.3</version>
                    </dependency>
                </dependencies>
                <configuration>
                    <useSystemClassLoader>false</useSystemClassLoader>
                    <properties>
                        <configurationParameters>
                            junit.jupiter.extensions.autodetection.enabled = true
                        </configurationParameters>
                    </properties>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.8.0</version>
                <configuration>
                    <release>11</release>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-surefire-plugin</artifactId>
                <version>2.19</version>
                <configuration>
                    <testFailureIgnore>true</testFailureIgnore>
                    <argLine>
                        --illegal-access=permit
                    </argLine>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

Я использую Java 11

Когда я ввожу эту тестовую команду:

mvn -ff clean integration-test

Я получаю этот выводэто заканчивается так:

Tests run: 2, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 0.001 sec - in com.github.(removedforstackoverflowpost)

Results :

Failed tests:
  SomeTest.testSomething1:13 expected: <1> but was: <2>

Tests run: 4, Failures: 1, Errors: 0, Skipped: 0

[ERROR] There are test failures.

Please refer to (removedforstackoverflowpost)/target/surefire-reports for the individual test results.
[INFO]
[INFO] --- maven-jar-plugin:2.4:jar (default-jar) @ (removedforstackoverflowpost) ---
[INFO] Building jar: (removedforstackoverflowpost)....-0.0.1.jar
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time:  3.360 s
[INFO] Finished at: 2018-12-12T00:45:03-08:00
[INFO] ------------------------------------------------------------------------

Я начинающий, поэтому прошу прощения за слишком упрощенный вопрос.Я новичок в Java / Maven / JUnit5, но я просто ищу то, что я должен сделать, чтобы тест вызывал ненулевой код выхода.Таким образом, мой запуск CI (я использую CircleCI, но это не имеет значения) будет показан как неудачный, когда тесты не пройдут.

Я работаю на Mac, и происходит нежелательное поведение, которое я описываю в этом билетеодинаково как на моей локальной рабочей станции Mac, так и в CircleCI.

1 Ответ

0 голосов
/ 27 декабря 2018

Строка 102 вашего pom.xml указывает Maven игнорировать сбои.Просто удалите <testFailureIgnore>true</testFailureIgnore> и сборка не удастся.

...