Поиск…


Синтаксис

  • тест mvn
  • mvn -Dtest = com.example.package.ExampleTest test

Тестирование класса Java с помощью JUnit и плагина Maven Surefire

Плагин Maven Surefire запускается на этапе тестирования процесса сборки Maven или когда test указан как цель Maven. Следующая структура каталогов и минимальный файл pom.xml настроят Maven для запуска теста.

Структура каталога внутри корневого каталога проекта:

─ project_root 
  ├─ pom.xml
  ├─ src
  │  ├─ main
  │  │  └─ java
  │  └─ test
  │     └─ java
  └─ target
     └─ ...

Содержание pom.xml :

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

Создайте файл PlusTenTest.java со следующим содержимым в PlusTenTest.java src/test/java/com/example/app проекта:

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

Аннотация @Test сообщает JUnit, что он должен запускать incrementTest() в качестве теста на этапе test процесса сборки Maven. Теперь создайте PlusTen.java в src/main/java/com/example/app :

package com.example.app;

public class PlusTen {
    public static int increment(int value) {
        return value;
    }
}

Запустите тест, открыв командную строку, перейдя в корневой каталог проекта и вызывая следующую команду:

mvn -Dtest=com.example.app.PlusTenTest test

Maven будет компилировать программу и запустить тестовый метод incrementTest() в PlusTenTest . Тест завершится ошибкой со следующей ошибкой:

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

Плагин Maven Surefire создает каталог /target/surefire-reports/ каталоге вашего проекта, содержащий файлы com.example.app.PlusTenTest.txt и TEST-com.example.app.PlusTenTest.xml , содержащие сведения об ошибках начала вышеизложенного.

Следуя тестовому шаблону разработки, измените PlusTen.java так, чтобы метод increments() работал правильно:

package com.example.app;

public class PlusTen {
    public static int increment(int value) {
        return value + 10;
    }
}

Вызовите команду еще раз:

mvn -Dtest=com.example.app.PlusTenTest test

Тест проходит:

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

Поздравляем! Вы протестировали Java-класс с использованием JUnit и плагина Maven Surefire.



Modified text is an extract of the original Stack Overflow Documentation
Лицензировано согласно CC BY-SA 3.0
Не связан с Stack Overflow