Apache Maven
Maven Surefire Plugin
Suche…
Syntax
- mvn test
- mvn -Dtest = com.example.package.ExampleTest test
Testen einer Java-Klasse mit JUnit und dem Maven Surefire-Plugin
Das Maven Surefire-Plugin wird während der Testphase des Maven-Build-Prozesses oder wenn der test
als Maven-Ziel angegeben ist, ausgeführt. Die folgende Verzeichnisstruktur und die minimale Datei pom.xml
konfigurieren Maven für die Ausführung eines Tests.
Verzeichnisstruktur im Stammverzeichnis des Projekts:
─ project_root
├─ pom.xml
├─ src
│ ├─ main
│ │ └─ java
│ └─ test
│ └─ java
└─ target
└─ ...
pom.xml
Inhalt:
<project>
<modelVersion>4.0.0</modelVersion>
<groupId>com.example</groupId>
<artifactId>company-app</artifactId>
<version>0.0.1</version>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
</dependencies>
</project>
Erstellen Sie eine Datei mit dem Namen PlusTenTest.java
mit den folgenden Inhalten im PlusTenTest.java
src/test/java/com/example/app
des Projekts:
package com.example.app;
import static org.junit.Assert.assertEquals;
import org.junit.Test;
public class PlusTenTest {
@Test
public void incrementTest() {
int result = PlusTen.increment(10);
assertEquals("PlusTen.increment(10) result", 20, result);
}
}
Die Annotation @Test
teilt JUnit mit, dass es in der test
des Maven-Build-Prozesses incrementTest()
als Test ausführen soll. Erstellen PlusTen.java
jetzt PlusTen.java
in src/main/java/com/example/app
:
package com.example.app;
public class PlusTen {
public static int increment(int value) {
return value;
}
}
Führen Sie den Test aus, indem Sie eine Eingabeaufforderung öffnen, zum Stammverzeichnis des Projekts navigieren und den folgenden Befehl aufrufen:
mvn -Dtest=com.example.app.PlusTenTest test
Maven kompiliert das Programm und führt die Testmethode incrementTest()
in PlusTenTest
. Der Test schlägt mit dem folgenden Fehler fehl:
...
Tests run: 1, Failures: 1, Errors: 0, Skipped: 0, Time elapsed: 0.005 sec <<< FAILURE! - in com.example.app.PlusTenTest
incrementTest(com.example.app.PlusTenTest) Time elapsed: 0.004 sec <<< FAILURE!
java.lang.AssertionError: PlusTen.increment(10) result expected:<20> but was:<10>
at org.junit.Assert.fail(Assert.java:88)
at org.junit.Assert.failNotEquals(Assert.java:743)
at org.junit.Assert.assertEquals(Assert.java:118)
at org.junit.Assert.assertEquals(Assert.java:555)
at com.example.app.PlusTenTest.incrementTest(PlusTenTest.java:12)
Results :
Failed tests:
PlusTenTest.incrementTest:12 PlusTen.increment(10) result expected:<20> but was:<10>
Tests run: 1, Failures: 1, Errors: 0, Skipped: 0
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 2.749 s
[INFO] Finished at: 2016-09-02T20:50:42-05:00
[INFO] Final Memory: 14M/209M
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-surefire-plugin:2.19.1:test (default-test) on project app: There are test failures.
...
Das Maven Surefire-Plugin erstellt im Verzeichnis Ihres Projekts ein Verzeichnis /target/surefire-reports/
das die Dateien com.example.app.PlusTenTest.txt
und TEST-com.example.app.PlusTenTest.xml
enthält der Ausgabe oben.
Ändern PlusTen.java
nach dem testgetriebenen Entwicklungsmuster PlusTen.java
damit die increments()
-Methode ordnungsgemäß funktioniert:
package com.example.app;
public class PlusTen {
public static int increment(int value) {
return value + 10;
}
}
Rufen Sie den Befehl erneut auf:
mvn -Dtest=com.example.app.PlusTenTest test
Der Test besteht:
-------------------------------------------------------
T E S T S
-------------------------------------------------------
Running com.example.app.PlusTenTest
Tests run: 1, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 0.028 sec
Results :
Tests run: 1, Failures: 0, Errors: 0, Skipped: 0
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 2.753 s
[INFO] Finished at: 2016-09-02T20:55:42-05:00
[INFO] Final Memory: 17M/322M
[INFO] ------------------------------------------------------------------------
Herzliche Glückwünsche! Sie haben eine Java-Klasse mit JUnit und dem Maven Surefire-Plugin getestet.