JUnit - Utilisation de base
Prenons maintenant un exemple de base pour illustrer le processus étape par étape d'utilisation de JUnit.
Créer une classe
Créez une classe java à tester, disons MessageUtil.java dans 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;
}
}
Créer une classe de cas de test
- Créez une classe de test java, par exemple TestJunit.java.
- Ajoutez une méthode de test testPrintMessage () à votre classe de test.
- Ajoutez un Annotaion @Test à la méthode testPrintMessage ().
- Implémentez la condition de test et vérifiez la condition à l'aide de l'API assertEquals de JUnit.
Créez un nom de fichier de classe Java TestJunit.java dans 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());
}
}
Créer une classe Test Runner
- Créez une classe java TestRunner.
- Utilisez la méthode runClasses de la classe JUnitCore de JUnit pour exécuter le scénario de test de la classe de test créée ci-dessus.
- Obtenez le résultat des cas de test exécutés dans l'objet du résultat.
- Obtenez les échecs en utilisant la méthode getFailures () de l'objet Result.
- Obtenez le résultat Success en utilisant la méthode wasSuccessful () de l'objet Result.
Créez un fichier de classe Java nommé TestRunner.java dans C:\>JUNIT_WORKSPACE pour exécuter des cas de test.
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());
}
}
Compilez les classes MessageUtil, Test case et Test Runner à l'aide de javac.
C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java
Exécutez maintenant le Test Runner, qui exécutera le scénario de test défini dans la classe de scénario de test fournie.
C:\JUNIT_WORKSPACE>java TestRunner
Vérifiez la sortie.
Hello World
true
Maintenant, mettez à jour TestJunit dans C:\>JUNIT_WORKSPACEde sorte que le test échoue. Modifiez la chaîne du message.
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());
}
}
Gardons le reste des classes tel quel et essayons d'exécuter le même 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());
}
}
Exécutez maintenant le Test Runner, qui exécutera le scénario de test défini dans la classe de scénario de test fournie.
C:\JUNIT_WORKSPACE>java TestRunner
Vérifiez la sortie.
Hello World
testPrintMessage(TestJunit): expected:<[New Wor]d> but was:<[Hello Worl]d>
false