प्रोट्रैक्टर - पहला टेस्ट लिखना
इस अध्याय में, हम समझते हैं कि प्रोट्रैक्टर में पहला टेस्ट कैसे लिखा जाता है।
प्रोटेक्टर द्वारा आवश्यक फाइलें
प्रोटेक्टर को चलाने के लिए निम्न दो फ़ाइलों की आवश्यकता होती है -
युक्ति या परीक्षण फ़ाइल
यह प्रोट्रैक्टर को चलाने के लिए महत्वपूर्ण फाइलों में से एक है। इस फ़ाइल में, हम अपना वास्तविक परीक्षण कोड लिखेंगे। परीक्षण कोड हमारे परीक्षण ढांचे के सिंटैक्स का उपयोग करके लिखा गया है।
उदाहरण के लिए, यदि हम उपयोग कर रहे हैं Jasmine ढांचा, तब के सिंटैक्स का उपयोग करके परीक्षण कोड लिखा जाएगा Jasmine। इस फ़ाइल में परीक्षण के सभी कार्यात्मक प्रवाह और दावे शामिल होंगे।
सरल शब्दों में, हम कह सकते हैं कि इस फ़ाइल में एप्लिकेशन के साथ बातचीत करने के लिए तर्क और लोकेटर हैं।
उदाहरण
निम्नलिखित एक सरल स्क्रिप्ट, TestSpecification.js है, जिसमें URL पर नेविगेट करने और पृष्ठ शीर्षक के लिए जांच करने के लिए परीक्षण मामला है -
//TestSpecification.js
describe('Protractor Demo', function() {
it('to check the page title', function() {
browser.ignoreSynchronization = true;
browser.get('https://www.tutorialspoint.com/tutorialslibrary.htm');
browser.driver.getTitle().then(function(pageTitle) {
expect(pageTitle).toEqual('Free Online Tutorials and Courses');
});
});
});
कोड स्पष्टीकरण
उपरोक्त विनिर्देश फ़ाइल का कोड निम्नानुसार समझाया जा सकता है -
ब्राउज़र
यह सभी ब्राउजर स्तर कमांड को संभालने के लिए प्रोटेक्टर द्वारा बनाया गया वैश्विक वैरिएबल है। यह मूल रूप से WebDriver के उदाहरण के आसपास एक आवरण है। browser.get () एक सरल सेलेनियम विधि है जो किसी विशेष पृष्ठ को लोड करने के लिए प्रोट्रैक्टर को बताएगी।
describe तथा it- दोनों जैस्मीन परीक्षण ढांचे के वाक्यविन्यास हैं। ’Describe’ जबकि हमारे परीक्षण मामले के अंत प्रवाह को समाप्त करने के लिए उपयोग किया जाता है ‘it’कुछ परीक्षण परिदृश्यों में शामिल हैं। हम कई हो सकते हैं‘it’ हमारे परीक्षण मामले कार्यक्रम में ब्लॉक।
Expect - यह एक दावा है जहां हम कुछ पूर्वनिर्धारित डेटा के साथ वेब पेज शीर्षक की तुलना कर रहे हैं।
ignoreSynchronization- यह ब्राउज़र का एक टैग है जिसका उपयोग तब किया जाता है जब हम गैर-कोणीय वेबसाइटों का परीक्षण करने का प्रयास करेंगे। प्रोट्रैक्टर को केवल कोणीय वेबसाइटों के साथ काम करने की उम्मीद है लेकिन अगर हम गैर-कोणीय वेबसाइटों के साथ काम करना चाहते हैं, तो इस टैग को सेट करना होगा“true”।
विन्यास फाइल
जैसा कि नाम से पता चलता है, यह फ़ाइल सभी प्रोटेक्टर कॉन्फ़िगरेशन विकल्पों के लिए स्पष्टीकरण प्रदान करती है। यह मूल रूप से प्रोटेक्टर को निम्नलिखित बताता है -
- परीक्षण या चश्मा फ़ाइलों को खोजने के लिए कहाँ
- कौन सा ब्राउज़र चुनना है
- किस टेस्टिंग फ्रेमवर्क का उपयोग करना है
- जहां सेलेनियम सर्वर के साथ बात करने के लिए
उदाहरण
निम्नलिखित सरल स्क्रिप्ट, config.js, परीक्षण कर रहा है
// config.js
exports.config = {
directConnect: true,
// Capabilities to be passed to the webdriver instance.
capabilities: {
'browserName': 'chrome'
},
// Framework to use. Jasmine is recommended.
framework: 'jasmine',
// Spec patterns are relative to the current working directory when
// protractor is called.
specs: ['TestSpecification.js'],
कोड स्पष्टीकरण
उपरोक्त कॉन्फ़िगरेशन फ़ाइल के कोड में तीन बुनियादी पैरामीटर हैं, जिन्हें निम्नानुसार समझाया जा सकता है -
क्षमताओं का पैरामीटर
इस पैरामीटर का उपयोग ब्राउज़र के नाम को निर्दिष्ट करने के लिए किया जाता है। यह conf.js फ़ाइल के निम्नलिखित कोड ब्लॉक में देखा जा सकता है -
exports.config = {
directConnect: true,
// Capabilities to be passed to the webdriver instance.
capabilities: {
'browserName': 'chrome'
},
जैसा कि ऊपर देखा गया है, यहां दिए गए ब्राउज़र का नाम 'क्रोम' है जो कि प्रोट्रेक्टर के लिए डिफ़ॉल्ट ब्राउज़र है। हम ब्राउजर का नाम भी बदल सकते हैं।
फ्रेमवर्क
इस पैरामीटर का उपयोग परीक्षण ढांचे के नाम को निर्दिष्ट करने के लिए किया जाता है। इसे config.js फ़ाइल के निम्नलिखित कोड ब्लॉक में देखा जा सकता है -
exports.config = {
directConnect: true,
// Framework to use. Jasmine is recommended.
framework: 'jasmine',
यहां हम 'चमेली' परीक्षण ढांचे का उपयोग कर रहे हैं।
स्रोत फ़ाइल घोषणा पैरामीटर
स्रोत फ़ाइल घोषणा के नाम को निर्दिष्ट करने के लिए इस पैरामीटर का उपयोग किया जाता है। यह conf.js फ़ाइल के निम्नलिखित कोड ब्लॉक में देखा जा सकता है -
exports.config = {
directConnect: true,
// Spec patterns are relative to the current working
directory when protractor is called.
specs: ['TsetSpecification.js'],
जैसा कि ऊपर देखा गया है, यहां दिए गए स्रोत फ़ाइल घोषणा का नाम है ‘TestSpecification.js’। ऐसा इसलिए है, क्योंकि इस उदाहरण के लिए हमने नाम के साथ विनिर्देश फ़ाइल बनाई हैTestSpecification.js।
कोड को निष्पादित करना
जैसा कि हमें प्रोटेक्टर को चलाने के लिए आवश्यक फाइलों और उनके कोडिंग के बारे में बुनियादी समझ मिली है, आइए हम उदाहरण को चलाने की कोशिश करें। हम इस उदाहरण को निष्पादित करने के लिए निम्नलिखित चरणों का पालन कर सकते हैं -
Step 1 - सबसे पहले, कमांड प्रॉम्प्ट खोलें।
Step 2 - इसके बाद, हमें उस डायरेक्टरी में जाने की जरूरत है, जहां हमने अपनी फाइल्स को config.js और सेव किया है TestSpecification.js।
Step 3 - अब, कमांड प्रोटेक्टर config.js चलाकर config.js फ़ाइल को निष्पादित करें।
नीचे दिखाया गया स्क्रीन शॉट उदाहरण को क्रियान्वित करने के लिए उपरोक्त चरणों की व्याख्या करेगा -
स्क्रीन शॉट में देखा गया है कि टेस्ट पास कर लिया गया है।
अब, मान लें कि यदि हम गैर-कोणीय वेबसाइटों का परीक्षण कर रहे हैं और इग्निस्सिंक्रनाइज़ेशन टैग को सही नहीं लगा रहे हैं तो कोड निष्पादित करने के बाद हमें त्रुटि मिलेगी "कोणीय पृष्ठ पर नहीं पाया जा सकता"।
इसे निम्नलिखित स्क्रीन शॉट में देखा जा सकता है -
रिपोर्ट पीढ़ी
अब तक, हमने परीक्षण मामलों को चलाने के लिए आवश्यक फाइलों और उनके कोडिंग के बारे में चर्चा की है। प्रोट्रैक्टर परीक्षण मामलों के लिए रिपोर्ट तैयार करने में भी सक्षम है। इस उद्देश्य के लिए, यह जैस्मीन का समर्थन करता है। JunitXMLReporter का उपयोग परीक्षण निष्पादन रिपोर्ट को स्वचालित रूप से उत्पन्न करने के लिए किया जा सकता है।
लेकिन इससे पहले, हमें निम्नलिखित आदेश की मदद से जैस्मीन रिपोर्टर स्थापित करने की आवश्यकता है -
npm install -g jasmine-reporters
जैसा कि आप देख सकते हैं, जैस्मीन रिपोर्टर्स को स्थापित करते समय -g विकल्प का उपयोग किया जाता है, यह इसलिए है क्योंकि हमने -g विकल्प के साथ विश्व स्तर पर प्रोट्रैक्टर स्थापित किया है।
चमेली-पत्रकारों को सफलतापूर्वक स्थापित करने के बाद, हमें निम्नलिखित कोड को अपने पहले इस्तेमाल किए गए config.js फ़ाइल में जोड़ना होगा -
onPrepare: function(){ //configure junit xml report
var jasmineReporters = require('jasmine-reporters');
jasmine.getEnv().addReporter(new jasmineReporters.JUnitXmlReporter({
consolidateAll: true,
filePrefix: 'guitest-xmloutput',
savePath: 'test/reports'
}));
अब, हमारी नई config.js फ़ाइल निम्नानुसार होगी -
// An example configuration file.
exports.config = {
directConnect: true,
// Capabilities to be passed to the webdriver instance.
capabilities: {
'browserName': 'chrome'
},
// Framework to use. Jasmine is recommended.
framework: 'jasmine',
// Spec patterns are relative to the current working directory when
// protractor is called.
specs: ['TestSpecification.js'],
//framework: "jasmine2", //must set it if you use JUnitXmlReporter
onPrepare: function(){ //configure junit xml report
var jasmineReporters = require('jasmine-reporters');
jasmine.getEnv().addReporter(new jasmineReporters.JUnitXmlReporter({
consolidateAll: true,
filePrefix: 'guitest-xmloutput',
savePath: 'reports'
}));
},
};
उपर्युक्त कॉन्फिग फ़ाइल को उसी तरह चलाने के बाद, हम पहले चला चुके हैं, यह रूट डायरेक्टरी के तहत रिपोर्ट वाली XML फ़ाइल उत्पन्न करेगा। reportsफ़ोल्डर। यदि परीक्षण सफल हो गया, तो रिपोर्ट नीचे दी जाएगी -
लेकिन, यदि परीक्षण विफल हो गया, तो रिपोर्ट नीचे दिखाई जाएगी -