JUnit - Test paramétré

JUnit 4 a introduit une nouvelle fonctionnalité appelée parameterized tests. Les tests paramétrés permettent à un développeur d'exécuter le même test encore et encore en utilisant des valeurs différentes. Vous devez suivre cinq étapes pour créer un test paramétré.

  • Annoter la classe de test avec @RunWith (Parameterized.class).

  • Créez une méthode statique publique annotée avec @Parameters qui renvoie une collection d'objets (sous forme de tableau) en tant qu'ensemble de données de test.

  • Créez un constructeur public qui prend ce qui équivaut à une «ligne» de données de test.

  • Créez une variable d'instance pour chaque "colonne" de données de test.

  • Créez votre ou vos cas de test en utilisant les variables d'instance comme source des données de test.

Le scénario de test sera appelé une fois pour chaque ligne de données. Voyons les tests paramétrés en action.

Créer une classe

Créez une classe java à tester, disons, PrimeNumberChecker.java dans C: \> JUNIT_WORKSPACE.

public class PrimeNumberChecker {
   public Boolean validate(final Integer primeNumber) {
      for (int i = 2; i < (primeNumber / 2); i++) {
         if (primeNumber % i == 0) {
            return false;
         }
      }
      return true;
   }
}

Créer une classe de cas de test paramétrée

Créez une classe de test java, par exemple, PrimeNumberCheckerTest.java. Créez un fichier de classe Java nomméPrimeNumberCheckerTest.java dans C: \> JUNIT_WORKSPACE.

import java.util.Arrays;
import java.util.Collection;
 
import org.junit.Test;
import org.junit.Before;

import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters;
import org.junit.runner.RunWith;
import static org.junit.Assert.assertEquals;

@RunWith(Parameterized.class)
public class PrimeNumberCheckerTest {
   private Integer inputNumber;
   private Boolean expectedResult;
   private PrimeNumberChecker primeNumberChecker;

   @Before
   public void initialize() {
      primeNumberChecker = new PrimeNumberChecker();
   }

   // Each parameter should be placed as an argument here
   // Every time runner triggers, it will pass the arguments
   // from parameters we defined in primeNumbers() method
	
   public PrimeNumberCheckerTest(Integer inputNumber, Boolean expectedResult) {
      this.inputNumber = inputNumber;
      this.expectedResult = expectedResult;
   }

   @Parameterized.Parameters
   public static Collection primeNumbers() {
      return Arrays.asList(new Object[][] {
         { 2, true },
         { 6, false },
         { 19, true },
         { 22, false },
         { 23, true }
      });
   }

   // This test will run 4 times since we have 5 parameters defined
   @Test
   public void testPrimeNumberChecker() {
      System.out.println("Parameterized Number is : " + inputNumber);
      assertEquals(expectedResult, 
      primeNumberChecker.validate(inputNumber));
   }
}

Créer une classe Test Runner

Créez un fichier de classe Java nommé TestRunner.java dans C: \> JUNIT_WORKSPACE pour exécuter le ou les 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(PrimeNumberCheckerTest.class);

      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

Compilez les classes PrimeNumberChecker, PrimeNumberCheckerTest et Test Runner à l'aide de javac.

C:\JUNIT_WORKSPACE>javac PrimeNumberChecker.java PrimeNumberCheckerTest.java
TestRunner.java

Exécutez maintenant le Test Runner, qui exécutera les cas de test définis dans la classe de cas de test fournie.

C:\JUNIT_WORKSPACE>java TestRunner

Vérifiez la sortie.

Parameterized Number is : 2
Parameterized Number is : 6
Parameterized Number is : 19
Parameterized Number is : 22
Parameterized Number is : 23
true