जैस्मिनजेएस - टेस्ट के बिल्डिंग ब्लॉक्स

इस अध्याय में, हम जैस्मीन द्वारा परीक्षण के निर्माण ब्लॉकों पर चर्चा करेंगे।

सुइट ब्लॉक

जैस्मीन जावास्क्रिप्ट के लिए एक परीक्षण ढांचा है। Suiteजैस्मीन ढांचे का बुनियादी निर्माण खंड है। एक विशिष्ट फ़ाइल या फ़ंक्शन के लिए लिखे गए समान प्रकार के परीक्षण मामलों का संग्रह एक सूट के रूप में जाना जाता है। इसमें दो अन्य ब्लॉक हैं, एक है“Describe()” और एक अन्य है “It()”

एक सुइट ब्लॉक में केवल दो पैरामीटर हो सकते हैं, एक “name of that suite” और दुसरी “Function declaration” वास्तव में हमारी इकाई कार्यक्षमता के लिए एक कॉल करता है जिसे परीक्षण किया जाना है।

निम्नलिखित उदाहरण में, हम एक सूट बनाएंगे जो यूनिट टेस्ट को फंक्शन ऐड करेगा add.jsफ़ाइल। इस उदाहरण में, हमारे पास हमारी JS फ़ाइल है“calculator.js” जिसे जैस्मीन के माध्यम से जांचा जाएगा, और इसी जैस्मीन कल्पना फ़ाइल है “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); 
   }); 
});

उपरोक्त फ़ंक्शन में, हमने दो फ़ंक्शन घोषित किए हैं। समारोहadd उस फ़ंक्शन और अन्य फ़ंक्शन के तर्क के रूप में दिए गए दो नंबर जोड़ देगा addAny एक तर्क के रूप में दिए गए किसी भी संख्या को जोड़ना चाहिए।

इस फ़ाइल को बनाने के बाद, हमें इस फ़ाइल को जोड़ना होगा “SpecRunner.html”हेड सेक्शन के अंदर। सफल संकलन पर, यह परिणामस्वरूप निम्न आउटपुट उत्पन्न करेगा।

नेस्टेड सूट ब्लॉक

सूट ब्लॉक में एक और सूट ब्लॉक के अंदर कई सूट ब्लॉक हो सकते हैं। निम्नलिखित उदाहरण आपको दिखाएंगे कि हम दूसरे सूट ब्लॉक के अंदर एक अलग सूट ब्लॉक कैसे बना सकते हैं। हम दो जावास्क्रिप्ट फाइलें बनाएंगे, एक का नाम“NestedSpec.js” और दूसरा नाम “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;    
   }  
};

कोड का उपरोक्त टुकड़ा चलने के परिणामस्वरूप निम्न आउटपुट उत्पन्न करेगा specRunner.html इस फाइल को हेड सेक्शन के अंदर डालने के बाद फाइल करें।

ब्लॉक का वर्णन करें

जैसा कि पहले वर्णन किया गया है कि ब्लॉक सूट सुइट का एक हिस्सा है। सुइट ब्लॉक की तरह, इसमें दो पैरामीटर होते हैं, एक“the name of the describe block” और दुसरी “function declaration”। हमारे आगामी उदाहरणों में, हम जैस्मीन सूट ब्लॉक के काम के प्रवाह को समझने के लिए कई वर्णन ब्लॉकों से गुजरेंगे। निम्नलिखित पूर्ण वर्णन ब्लॉक का एक उदाहरण है।

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

आईटी ब्लॉक

वर्णन ब्लॉक की तरह हमें भी आईटी ब्लॉक में पेश किया गया है। यह एक वर्णन ब्लॉक के भीतर जाता है। यह वह ब्लॉक है जिसमें वास्तव में प्रत्येक यूनिट टेस्ट केस होता है। निम्नलिखित कोड में, के टुकड़े हैंIT एक के अंदर ब्लॉक describe खंड मैथा।

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); 
   });     
}

ब्लॉक की अपेक्षा करें

चमेली Expectआपको आवश्यक फ़ंक्शन या जावास्क्रिप्ट फ़ाइल से अपनी अपेक्षा लिखने की अनुमति देता है। इसके अंतर्गत आता हैITखंड मैथा। एक IT ब्लॉक में एक से अधिक Expect ब्लॉक हो सकते हैं।

निम्नलिखित उम्मीद ब्लॉक का एक उदाहरण है। यह अपेक्षा करता है कि ब्लॉक आपके जावास्क्रिप्ट फंक्शन या जावास्क्रिप्ट फाइल को यूनिट करने के लिए कई तरह के तरीके प्रदान करता है। एक्सपेक्ट ब्लॉक में से प्रत्येक को ए के रूप में भी जाना जाता हैmatcher। मैचर्स के दो अलग-अलग प्रकार होते हैं, एकinbuilt matcher और दुसरी 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); 
   });     
}

आगामी अध्यायों में, हम एक्सपेक्ट ब्लॉक के विभिन्न इनबिल्ट तरीकों के विभिन्न उपयोगों पर चर्चा करेंगे।