JUnit - Utilisation de l'assertion

Affirmation

Toutes les assertions sont dans la classe Assert.

public class Assert extends java.lang.Object

Cette classe fournit un ensemble de méthodes d'assertion, utiles pour écrire des tests. Seules les affirmations ayant échoué sont enregistrées. Certaines des méthodes importantes de la classe Assert sont les suivantes:

N ° Sr. Méthodes et description
1

void assertEquals(boolean expected, boolean actual)

Vérifie que deux primitives / objets sont égaux.

2

void assertTrue(boolean condition)

Vérifie qu'une condition est vraie.

3

void assertFalse(boolean condition)

Vérifie qu'une condition est fausse.

4

void assertNotNull(Object object)

Vérifie qu'un objet n'est pas nul.

5

void assertNull(Object object)

Vérifie qu'un objet est nul.

6

void assertSame(object1, object2)

La méthode assertSame () teste si deux références d'objet pointent vers le même objet.

sept

void assertNotSame(object1, object2)

La méthode assertNotSame () teste si deux références d'objet ne pointent pas vers le même objet.

8

void assertArrayEquals(expectedArray, resultArray);

La méthode assertArrayEquals () testera si deux tableaux sont égaux l'un à l'autre.

Utilisons certaines des méthodes mentionnées ci-dessus dans un exemple. Créez un fichier de classe Java nomméTestAssertions.java dans C: \> JUNIT_WORKSPACE.

import org.junit.Test;
import static org.junit.Assert.*;

public class TestAssertions {

   @Test
   public void testAssertions() {
      //test data
      String str1 = new String ("abc");
      String str2 = new String ("abc");
      String str3 = null;
      String str4 = "abc";
      String str5 = "abc";
		
      int val1 = 5;
      int val2 = 6;

      String[] expectedArray = {"one", "two", "three"};
      String[] resultArray =  {"one", "two", "three"};

      //Check that two objects are equal
      assertEquals(str1, str2);

      //Check that a condition is true
      assertTrue (val1 < val2);

      //Check that a condition is false
      assertFalse(val1 > val2);

      //Check that an object isn't null
      assertNotNull(str1);

      //Check that an object is null
      assertNull(str3);

      //Check if two object references point to the same object
      assertSame(str4,str5);

      //Check if two object references not point to the same object
      assertNotSame(str1,str3);

      //Check whether two arrays are equal to each other.
      assertArrayEquals(expectedArray, resultArray);
   }
}

Ensuite, 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 TestRunner2 {
   public static void main(String[] args) {
      Result result = JUnitCore.runClasses(TestAssertions.class);
		
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

Compilez le scénario de test et les classes Test Runner à l'aide de javac.

C:\JUNIT_WORKSPACE>javac TestAssertions.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.

true

Annotation

Les annotations sont comme des méta-balises que vous pouvez ajouter à votre code et les appliquer à des méthodes ou en classe. Ces annotations dans JUnit fournissent les informations suivantes sur les méthodes de test -

  • quelles méthodes vont être exécutées avant et après les méthodes de test.
  • quelles méthodes s'exécutent avant et après toutes les méthodes, et.
  • quelles méthodes ou classes seront ignorées lors de l'exécution.

Le tableau suivant fournit une liste d'annotations et leur signification dans JUnit -

N ° Sr. Annotation et description
1

@Test

L'annotation Test indique à JUnit que la méthode publique void à laquelle elle est attachée peut être exécutée en tant que scénario de test.

2

@Before

Plusieurs tests nécessitent des objets similaires créés avant de pouvoir s'exécuter. L'annotation d'une méthode void publique avec @Before entraîne l'exécution de cette méthode avant chaque méthode Test.

3

@After

Si vous allouez des ressources externes dans une méthode Before, vous devez les libérer après l'exécution du test. L'annotation d'une méthode void publique avec @After entraîne l'exécution de cette méthode après la méthode Test.

4

@BeforeClass

L'annotation d'une méthode void statique publique avec @BeforeClass entraîne son exécution une fois avant l'une des méthodes de test de la classe.

5

@AfterClass

Cela exécutera la méthode une fois tous les tests terminés. Cela peut être utilisé pour effectuer des activités de nettoyage.

6

@Ignore

L'annotation Ignorer est utilisée pour ignorer le test et ce test ne sera pas exécuté.

Créez un fichier de classe Java nommé JunitAnnotation.java dans C: \> JUNIT_WORKSPACE pour tester l'annotation.

import org.junit.After;
import org.junit.AfterClass;

import org.junit.Before;
import org.junit.BeforeClass;

import org.junit.Ignore;
import org.junit.Test;

public class JunitAnnotation {
	
   //execute before class
   @BeforeClass
   public static void beforeClass() {
      System.out.println("in before class");
   }

   //execute after class
   @AfterClass
   public static void  afterClass() {
      System.out.println("in after class");
   }

   //execute before test
   @Before
   public void before() {
      System.out.println("in before");
   }
	
   //execute after test
   @After
   public void after() {
      System.out.println("in after");
   }
	
   //test case
   @Test
   public void test() {
      System.out.println("in test");
   }
	
   //test case ignore and will not execute
   @Ignore
   public void ignoreTest() {
      System.out.println("in ignore test");
   }
}

Ensuite, créez un fichier de classe Java nommé TestRunner.java dans C: \> JUNIT_WORKSPACE pour exécuter des annotations.

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(JunitAnnotation.class);
		
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

Compilez le scénario de test et les classes Test Runner à l'aide de javac.

C:\JUNIT_WORKSPACE>javac JunitAnnotation.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.

in before class
in before
in test
in after
in after class
true