JUnit предоставляет удобную опцию Timeout. Если тестовый случай занимает больше времени, чем указанное количество миллисекунд, JUnit автоматически помечает его как неудачный. Параметр timeout используется вместе с аннотацией @Test. Давайте посмотрим @Test (тайм-аут) в действии.
Создать класс
Создайте Java-класс для тестирования, скажем, MessageUtil.java в C: \> JUNIT_WORKSPACE.
Добавьте бесконечный цикл while внутри метода printMessage ().
/* * This class prints the given message on console. */ public class MessageUtil { private String message; //Constructor //@param message to be printed public MessageUtil(String message){ this.message = message; } // prints the message public void printMessage(){ System.out.println(message); while(true); } // add "Hi!" to the message public String salutationMessage(){ message = "Hi!" + message; System.out.println(message); return message; } }
Создать тестовый класс
Создайте тестовый класс Java, скажем, TestJunit.java . Добавьте тайм-аут 1000 в testPrintMessage () контрольный пример.
Создайте файл класса Java с именем TestJunit.java в C: \> JUNIT_WORKSPACE.
import org.junit.Test; import org.junit.Ignore; import static org.junit.Assert.assertEquals; public class TestJunit { String message = "Robert"; MessageUtil messageUtil = new MessageUtil(message); @Test(timeout = 1000) public void testPrintMessage() { System.out.println("Inside testPrintMessage()"); messageUtil.printMessage(); } @Test public void testSalutationMessage() { System.out.println("Inside testSalutationMessage()"); message = "Hi!" + "Robert"; assertEquals(message,messageUtil.salutationMessage()); } }
Создать класс Runner Test
Создайте файл класса Java с именем TestRunner.java в C: \> JUNIT_WORKSPACE для выполнения тестовых примеров.
import org.junit.runner.JUnitCore; import org.junit.runner.Result; import org.junit.runner.notification.Failure; public class TestRunner { public static void main(String[] args) { Result result = JUnitCore.runClasses(TestJunit.class); for (Failure failure : result.getFailures()) { System.out.println(failure.toString()); } System.out.println(result.wasSuccessful()); } }
Скомпилируйте классы MessageUtil, Test case и Test Runner, используя javac.
C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java
Теперь запустите Test Runner, который запустит тестовые наборы, определенные в предоставленном классе Test Case.
C:\JUNIT_WORKSPACE>java TestRunner
Проверьте вывод. В тестовом примере testPrintMessage () будет указано, что модульное тестирование не выполнено.