JasmineJS - Blocs de construction du test

Dans ce chapitre, nous aborderons les éléments de base du test de Jasmine.

Bloc Suite

Jasmine est un framework de test pour JavaScript. Suiteest le bloc de construction de base du framework Jasmine. La collection de cas de test de type similaire écrits pour un fichier ou une fonction spécifique est appelée une suite. Il contient deux autres blocs, l'un est“Describe()” et un autre est “It()”.

Un bloc Suite ne peut avoir que deux paramètres, un “name of that suite” et un autre “Function declaration” qui appelle en fait la fonctionnalité de notre unité qui doit être testée.

Dans l'exemple suivant, nous allons créer une suite qui effectuera un test unitaire ajouter une fonction dans add.jsfichier. Dans cet exemple, nous avons notre fichier JS nommé“calculator.js” qui sera testé via Jasmine, et le fichier de spécification Jasmine correspondant est “CalCulatorSpec.js”.

Calculator.js

window.Calculator = { 
   
   currentVal:0,  
   varAfterEachExmaple:0, 
   
   add:function (num1) { 
      this.currentVal += num1; 
      return this.currentVal;    
   },     
   
   addAny:function () {    
      var sum = this.currentVal; 
		
      for(var i = 0; i < arguments.length; i++) { 
         sum += arguments[i]; 
      } 
      
      this.currentVal = sum; 
      Return  this.currentVal; 
   }, 
};

CalCulatorSpec.js

describe("calculator",function() { 
   
   //test case: 1  
   it("Should retain the current value of all time", function () {
      expect(Calculator.currentVal).toBeDefined();
      expect(Calculator.currentVal).toEqual(0);  
   }); 
   
   //test case: 2  
   it("should add numbers",function() {
      expect(Calculator.add(5)).toEqual(5); 
      expect(Calculator.add(5)).toEqual(10);  
   });         
    
   //test case :3   
   it("Should add any number of numbers",function () {
      expect(Calculator.addAny(1,2,3)).toEqual(6); 
   }); 
});

Dans la fonction ci-dessus, nous avons déclaré deux fonctions. Fonctionadd ajoutera deux nombres donnés en argument à cette fonction et une autre fonction addAny devrait ajouter tous les nombres donnés en argument.

Après avoir créé ce fichier, nous devons ajouter ce fichier dans “SpecRunner.html”à l'intérieur de la section de tête. En cas de compilation réussie, cela générera la sortie suivante en conséquence.

Bloc de suites imbriquées

Le bloc Suite peut avoir de nombreux blocs suite à l'intérieur d'un autre bloc Suite. L'exemple suivant vous montrera comment nous pouvons créer un bloc de suite différent dans un autre bloc de suite. Nous allons créer deux fichiers JavaScript, l'un nommé“NestedSpec.js” et un autre nommé “nested.js”.

NestedSpec.js

describe("nested",function() { 
   
   // Starting of first suite block  
   // First block    
	
   describe("Retaining values ",function () {
   
      //test case:1    
      it ("Should retain the current value of all time", function () { 
         expect(nested.currentVal).toBeDefined();   
         expect(nested.currentVal).toEqual(0);   
      });    
   }); //end of the suite block   

   //second suite block 
   describe("Adding single number ",function () {     
   
      //test case:2 
      it("should add numbers",function() { 
         expect(nested.add(5)).toEqual(5); 
         expect(nested.add(5)).toEqual(10); 
      });         
   }); //end of the suite block  

   //third suite block 
   describe("Adding Different Numbers",function () {  
   
      //test case:3 
      it("Should add any number of numbers",function() {  
         expect(nested.addAny(1,2,3)).toEqual(6);  
      });    
   }); //end of the suite block 
});

Nested.js

window.nested = { 
   
   currentVal: 0,
	
   add:function (num1) {  
      this.currentVal += num1;     
      return this.currentVal;    
   },
   
   addAny:function () { 
      Var sum = this.currentVal; 
		
      for(var i = 0;i < arguments.length; i++) { 
         sum += arguments[i]; 
      } 
		
      this.currentVal = sum; 
      return this.currentVal;    
   }  
};

Le morceau de code ci-dessus générera la sortie suivante à la suite de l'exécution specRunner.html fichier après avoir ajouté ce fichier dans la section head.

Décrire le bloc

Comme indiqué précédemment, le bloc describe fait partie du bloc Suite. Comme le bloc Suite, il contient deux paramètres, un“the name of the describe block” et un autre “function declaration”. Dans nos prochains exemples, nous passerons en revue de nombreux blocs de description pour comprendre le flux de travail du bloc de la suite Jasmine. Voici un exemple de bloc de description complet.

describe("Adding single number ",function () { 
   
   it("should add numbers",function() { 
      expect(nested.add(5)).toEqual(5); 
      expect(nested.add(5)).toEqual(10); 
   });     
}

Bloc informatique

Comme pour décrire le bloc, nous avons également été introduits dans le bloc informatique. Il entre dans un bloc de description. C'est le bloc qui contient en fait chaque cas de test unitaire. Dans le code suivant, il y a des morceaux deIT bloquer à l'intérieur d'un describe bloquer.

describe("Adding single number ",function () { 
   
   // test case : 1   
   it("should add numbers",function() {  
      expect(nested.add(5)).toEqual(5); 
      expect(nested.add(5)).toEqual(10); 
   });         
    
   //test case : 2 
   it("should add numbers",function() { 
      expect(nested.addAny(1,2,3)).toEqual(6); 
   });     
}

Attendre un bloc

Jasmin Expectvous permet d'écrire vos attentes à partir de la fonction requise ou du fichier JavaScript. Il vient sousITbloquer. Un bloc informatique peut avoir plus d'un bloc Expect.

Voici un exemple de bloc Expect. Ce bloc expect fournit une grande variété de méthodes pour tester l'unité votre fonction JavaScript ou votre fichier JavaScript. Chacun des blocs Expect est également appelématcher. Il existe deux types différents de matchers, uninbuilt matcher et un autre user defined matchers.

describe("Adding single number ",function () {   
   
   // test case : 1 
   it("should add numbers",function() {
      expect(nested.add(5)).toEqual(5); 
      expect(nested.add(5)).toEqual(10);
   });          
   
   //test case : 2 
   it("should add numbers",function() {
      expect(nested.addAny(1,2,3)).toEqual(6); 
   });     
}

Dans les prochains chapitres, nous discuterons de diverses utilisations des différentes méthodes intégrées du bloc Expect.