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