JUnit - Uso básico
Tengamos ahora un ejemplo básico para demostrar el proceso paso a paso de usar JUnit.
Crear una clase
Cree una clase java para probar, digamos, MessageUtil.java en C:\>JUNIT_WORKSPACE
/*
* 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 String printMessage(){
System.out.println(message);
return message;
}
}
Crear clase de caso de prueba
- Cree una clase de prueba de Java, por ejemplo, TestJunit.java.
- Agregue un método de prueba testPrintMessage () a su clase de prueba.
- Agregue una Annotaion @Test al método testPrintMessage ().
- Implemente la condición de prueba y verifique la condición usando la API assertEquals de JUnit.
Cree un nombre de archivo de clase java TestJunit.java en C:\>JUNIT_WORKSPACE.
import org.junit.Test;
import static org.junit.Assert.assertEquals;
public class TestJunit {
String message = "Hello World";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
assertEquals(message,messageUtil.printMessage());
}
}
Crear clase de corredor de pruebas
- Cree una clase Java de TestRunner.
- Utilice el método runClasses de la clase JUnitCore de JUnit para ejecutar el caso de prueba de la clase de prueba creada anteriormente.
- Obtenga el resultado de los casos de prueba ejecutados en el objeto de resultado.
- Obtenga fallas usando el método getFailures () del objeto Result.
- Obtenga un resultado exitoso utilizando el método wasSuccessful () del objeto Result.
Cree un archivo de clase java llamado TestRunner.java en C:\>JUNIT_WORKSPACE para ejecutar caso (s) de prueba.
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());
}
}
Compile las clases MessageUtil, Test case y Test Runner usando javac.
C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java
Ahora ejecute Test Runner, que ejecutará el caso de prueba definido en la clase de Caso de prueba proporcionada.
C:\JUNIT_WORKSPACE>java TestRunner
Verifique la salida.
Hello World
true
Ahora actualice TestJunit en C:\>JUNIT_WORKSPACEpara que la prueba falle. Cambie la cadena del mensaje.
import org.junit.Test;
import static org.junit.Assert.assertEquals;
public class TestJunit {
String message = "Hello World";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
message = "New Word";
assertEquals(message,messageUtil.printMessage());
}
}
Mantengamos el resto de las clases como están e intentemos ejecutar el mismo Test Runner.
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());
}
}
Ahora ejecute Test Runner, que ejecutará el caso de prueba definido en la clase de Caso de prueba proporcionada.
C:\JUNIT_WORKSPACE>java TestRunner
Verifique la salida.
Hello World
testPrintMessage(TestJunit): expected:<[New Wor]d> but was:<[Hello Worl]d>
false