प्रोट्रैक्टर - प्रोट्रैक्टर और सेलेनियम सर्वर

जैसा कि पहले चर्चा की गई है, प्रोट्रैक्टर एक खुला स्रोत है, जो कि कोणीय और एंगुलरजेएस अनुप्रयोगों के लिए एंड-टू-एंड परीक्षण रूपरेखा है। यह Node.js कार्यक्रम है। दूसरी ओर, सेलेनियम एक ब्राउज़र स्वचालन ढांचा है जिसमें सेलेनियम सर्वर, वेबड्राइवर एपीआई और वेबड्राइवर ब्राउज़र ड्राइवर शामिल हैं।

सेलेनियम के साथ रक्षक

अगर हम प्रोटेक्टर और सेलेनियम के संयोजन के बारे में बात करते हैं, तो प्रोट्रैक्टर एक स्वचालित परीक्षण बुनियादी ढांचा प्रदान करने के लिए सेलेनियम सर्वर के साथ काम कर सकता है। बुनियादी ढांचा उपयोगकर्ता के इंटरैक्शन को एक कोणीय अनुप्रयोग के साथ अनुकरण कर सकता है जो ब्राउज़र या मोबाइल डिवाइस पर चल रहा है। प्रोट्रैक्टर और सेलेनियम के संयोजन को तीन विभाजनों में विभाजित किया जा सकता है अर्थात् परीक्षण, सर्वर और ब्राउज़र, जैसा कि निम्नलिखित चित्र में दिखाया गया है -

सेलेनियम वेबड्राइवर प्रक्रियाएं

जैसा कि हमने ऊपर चित्र में देखा है, सेलेनियम वेबड्राइवर का उपयोग करने वाले एक परीक्षण में निम्नलिखित तीन प्रक्रियाएं शामिल हैं -

  • परीक्षण स्क्रिप्ट
  • सर्वर
  • ब्राउज़र

इस खंड में, हम इन तीन प्रक्रियाओं के बीच संचार पर चर्चा करते हैं।

टेस्ट लिपियों और सर्वर के बीच संचार

पहले दो प्रक्रियाओं के बीच संचार - परीक्षण स्क्रिप्ट और सर्वर सेलेनियम सर्वर के काम पर निर्भर करता है। दूसरे शब्दों में, हम कह सकते हैं कि सेलेनियम सर्वर जिस तरह से चल रहा है वह परीक्षण स्क्रिप्ट और सर्वर के बीच संचार प्रक्रिया को आकार देगा।

सेलेनियम सर्वर स्टैंडअलोन सेलेनियम सर्वर (सेलेनियम-सर्वर-स्टैंडअलोन.जर) के रूप में हमारी मशीन पर स्थानीय रूप से चल सकता है या यह एक सेवा (सॉस लैब) के माध्यम से दूरस्थ रूप से चला सकता है। स्वसंपूर्ण सेलेनियम सर्वर के मामले में, Node.js और सेलेनियम सर्वर के बीच एक http संचार होगा।

सर्वर और ब्राउज़र के बीच संचार

जैसा कि हम जानते हैं कि सर्वर परीक्षण स्क्रिप्ट से उसी की व्याख्या करने के बाद ब्राउज़र को कमांड अग्रेषित करने के लिए जिम्मेदार है। इसीलिए सर्वर और ब्राउज़र को भी संचार माध्यम की आवश्यकता होती है और यहाँ संचार की सहायता से किया जाता हैJSON WebDriver Wire Protocol। ब्राउज़र ब्राउज़र ड्राइवर के साथ विस्तारित होता है जो कमांड की व्याख्या करने के लिए उपयोग किया जाता है।

सेलेनियम वेबड्राइवर प्रक्रियाओं और उनके संचार के बारे में उपरोक्त अवधारणा को निम्नलिखित चित्र की मदद से समझा जा सकता है -

प्रोट्रैक्टर के साथ काम करते समय, बहुत ही पहली प्रक्रिया, जो कि टेस्ट स्क्रिप्ट है, को Node.js का उपयोग करके चलाया जाता है, लेकिन ब्राउज़र पर कोई भी कार्य करने से पहले यह सुनिश्चित करने के लिए एक अतिरिक्त कमांड भेजेगा कि यह सुनिश्चित किया जा रहा है कि परीक्षण किया जा रहा एप्लिकेशन स्थिर है।

सेलेनियम सर्वर की स्थापना

सेलेनियम सर्वर हमारे परीक्षण स्क्रिप्ट और ब्राउज़र ड्राइवर के बीच एक प्रॉक्सी सर्वर की तरह काम करता है। यह मूल रूप से हमारी परीक्षण स्क्रिप्ट से WebDriver तक की कमांड को आगे बढ़ाता है और WebDriver से हमारी परीक्षण स्क्रिप्ट पर प्रतिक्रिया देता है। सेलेनियम सर्वर की स्थापना के लिए निम्नलिखित विकल्प हैं जो इसमें शामिल हैंconf.js परीक्षण स्क्रिप्ट की फ़ाइल -

स्टैंडअलोन सेलेनियम सर्वर

यदि हम अपने स्थानीय मशीन पर सर्वर चलाना चाहते हैं, तो हमें स्टैंडअलोन सेलेनियम सर्वर स्थापित करने की आवश्यकता है। स्टैंडअलोन सेलेनियम सर्वर को स्थापित करने की शर्त JDK (जावा डेवलपमेंट किट) है। हमें अपने स्थानीय मशीन पर JDK स्थापित करना होगा। हम कमांड लाइन से निम्न कमांड चलाकर इसकी जांच कर सकते हैं -

java -version

अब, हमारे पास सेलेनियम सर्वर को मैन्युअल रूप से स्थापित करने या परीक्षण स्क्रिप्ट से शुरू करने का विकल्प है।

मैन्युअल रूप से सेलेनियम सर्वर स्थापित करना और शुरू करना

सेलेनियम सर्वर को मैन्युअल रूप से स्थापित करने और शुरू करने के लिए, हमें वेबड्राइवर-मैनेजर कमांड लाइन टूल का उपयोग करना होगा जो प्रोट्रैक्टर के साथ आता है। सेलेनियम सर्वर को स्थापित करने और शुरू करने के चरण इस प्रकार हैं -

Step 1- पहला कदम सेलेनियम सर्वर और क्रोमड्राइव को स्थापित करना है। यह निम्नलिखित कमांड चलाने की मदद से किया जा सकता है -

webdriver-manager update

Step 2- अगला, हमें सर्वर शुरू करने की आवश्यकता है। यह निम्नलिखित कमांड चलाने की मदद से किया जा सकता है -

webdriver-manager start

Step 3- आख़िर में हमें रनिंग सर्वर के एड्रेस पर config फाइल में seleniumAddress सेट करना होगा। डिफ़ॉल्ट पता होगाhttp://localhost:4444/wd/hub

टेस्ट स्क्रिप्ट से सेलेनियम सर्वर शुरू करना

टेस्ट स्क्रिप्ट से सेलेनियम सर्वर शुरू करने के लिए, हमें अपनी कॉन्फ़िगर फाइल में निम्नलिखित विकल्प सेट करने होंगे -

  • Location of jar file - हमें seleniumSergenJar को सेट करके config फाइल में स्टैंडअलोन सेलेनियम सर्वर के लिए जार फ़ाइल का स्थान सेट करने की आवश्यकता है।

  • Specifying the port- हमें स्टैंडअलोन सेलेनियम सर्वर को शुरू करने के लिए पोर्ट को निर्दिष्ट करने की भी आवश्यकता है। इसे seleniumPort सेट करके config फाइल में निर्दिष्ट किया जा सकता है। डिफ़ॉल्ट पोर्ट 4444 है।

  • Array of command line options- हमें सर्वर पर जाने के लिए कमांड लाइन विकल्पों की सरणी सेट करने की भी आवश्यकता है। इसे seleniumArgs सेट करके config फाइल में निर्दिष्ट किया जा सकता है। यदि आपको कमांड के सरणी की पूरी सूची की आवश्यकता है, तो सर्वर को इसके साथ शुरू करें-help झंडा।

रिमोट सेलेनियम सर्वर के साथ काम करना

हमारे परीक्षण को चलाने के लिए एक अन्य विकल्प दूर सेलेनियम सर्वर का उपयोग करना है। सर्वर को दूरस्थ रूप से उपयोग करने के लिए शर्त यह है कि हमारे पास सर्वर को होस्ट करने वाली सेवा के साथ एक खाता होना चाहिए। प्रोटेक्टर के साथ काम करते समय हमारे पास सर्वर की मेजबानी करने वाली निम्नलिखित सेवाओं के लिए अंतर्निहित समर्थन है -

TestObject

रिमोट सेलेनियम सर्वर के रूप में TestObject का उपयोग करने के लिए, हमें TestobjectUser, हमारे TestObject खाते का उपयोगकर्ता नाम और TestobjectKey, हमारे TestObject खाते की API कुंजी सेट करने की आवश्यकता है।

BrowserStack

रिमोट सेलेनियम सर्वर के रूप में ब्राउज़रस्टैक का उपयोग करने के लिए, हमें ब्राउज़रस्टैक यूज़र, हमारे ब्राउज़रस्टैक खाते का उपयोगकर्ता नाम और ब्राउज़रस्टैकके, हमारे ब्राउज़रस्टैक खाते की एपीआई कुंजी सेट करने की आवश्यकता है।

सॉस लैब्स

रिमोट सेलेनियम सर्वर के रूप में सॉस लैब का उपयोग करने के लिए, हमें सॉस सॉस, हमारे सॉस लैब खाते का उपयोगकर्ता नाम और सॉस सॉस, हमारे सॉस लैब खाते की एपीआई कुंजी सेट करने की आवश्यकता है।

Kobiton

रिमोट सेलेनियम सर्वर के रूप में कोबिटोन का उपयोग करने के लिए हमें अपने कोबीटन खाते के एपीआई कुंजी कोबिटॉन खाते के उपयोगकर्ता नाम और कोबिटोनकेबर कोबिटोनयूजर सेट करने की आवश्यकता है।

सीधे सेलेनियम सर्वर का उपयोग किए बिना ब्राउज़र ड्राइवर से कनेक्ट करना

हमारे परीक्षण को चलाने के लिए एक और विकल्प सेलेनियम सर्वर का उपयोग किए बिना सीधे ब्राउज़र ड्राइवर से कनेक्ट करना है। प्रोटेक्टर सीधे परीक्षण कर सकता है, सेलेनियम सर्वर के उपयोग के बिना, क्रोमकॉन और फायरफॉक्स के खिलाफ डायरेक्टकनेक्ट को सेट करके: कॉन्फिग फाइल में सही।

ब्राउज़र की स्थापना

ब्राउज़र को कॉन्फ़िगर करने और स्थापित करने से पहले, हमें यह जानना होगा कि कौन से ब्राउज़र प्रोट्रैक्टर द्वारा समर्थित हैं। निम्नलिखित प्रोट्रेक्टर द्वारा समर्थित ब्राउज़रों की सूची है -

  • ChromeDriver
  • FirefoxDriver
  • SafariDriver
  • IEDriver
  • Appium-iOS/Safari
  • Appium-Android/Chrome
  • Selendroid
  • PhantomJS

ब्राउज़र को सेट करने और कॉन्फ़िगर करने के लिए, हमें प्रोटेक्टर की फ़ाइल को कॉन्फ़िगर करने की आवश्यकता होती है क्योंकि ब्राउज़र सेटअप कॉन्फ़िगरेशन फ़ाइल की क्षमताओं के भीतर किया जाता है।

क्रोम की स्थापना

Chrome ब्राउज़र को सेट करने के लिए, हमें निम्नानुसार क्षमता ऑब्जेक्ट सेट करना होगा

capabilities: {
   'browserName': 'chrome'
}

हम क्रोम-विशिष्ट विकल्पों को भी जोड़ सकते हैं जो क्रोमोसेस में नेस्टेड हैं और इसकी पूरी सूची को देखा जा सकता है https://sites.google.com/a/chromium.org/chromedriver/capabilities।

उदाहरण के लिए, यदि आप ऊपरी दाएं में एफपीएस-काउंटर जोड़ना चाहते हैं, तो इसे विन्यास फाइल में निम्नानुसार किया जा सकता है -

capabilities: {
   'browserName': 'chrome',
   'chromeOptions': {
      'args': ['show-fps-counter=true']
   }
},

फ़ायरफ़ॉक्स की स्थापना

फ़ायरफ़ॉक्स ब्राउज़र स्थापित करने के लिए, हमें निम्नानुसार क्षमता ऑब्जेक्ट सेट करना होगा -

capabilities: {
   'browserName': 'firefox'
}

हम फ़ायरफ़ॉक्स-विशिष्ट विकल्पों को भी जोड़ सकते हैं जो moz में निहित हैं: firefoxOptions ऑब्जेक्ट और इसकी पूरी सूची यहाँ देखी जा सकती है https://github.com/mozilla/geckodriver#firefox-capabilities।

उदाहरण के लिए, यदि आप फ़ायरफ़ॉक्स पर अपना परीक्षण सुरक्षित मोड में चलाना चाहते हैं, तो इसे कॉन्फ़िगरेशन फ़ाइल में निम्नानुसार किया जा सकता है -

capabilities: {
   'browserName': 'firefox',
   'moz:firefoxOptions': {
     'args': ['—safe-mode']
   }
},

अन्य ब्राउज़र सेट करना

क्रोम या फ़ायरफ़ॉक्स के अलावा किसी अन्य ब्राउज़र को स्थापित करने के लिए, हमें एक अलग बाइनरी स्थापित करने की आवश्यकता है https://docs.seleniumhq.org/download/।

फंटनजेएस की स्थापना

दरअसल, फैंटम जेएस अब इसके दुर्घटनाग्रस्त होने के कारण समर्थित नहीं है। इसके बजाय यह हेडलेस क्रोम या हेडलेस फ़ायरफ़ॉक्स का उपयोग करने की सिफारिश की जाती है। उन्हें निम्नानुसार स्थापित किया जा सकता है -

हेडलेस क्रोम की स्थापना के लिए, हमें क्रोम को फ्लैगलेस के साथ शुरू करने की आवश्यकता है -

capabilities: {
   'browserName': 'chrome',
   'chromeOptions': {
      'args': [“--headless”, “--disable-gpu”, “--window-size=800,600”]
   }
},

हेडलेस फ़ायरफ़ॉक्स की स्थापना के लिए, हमें फ़ायरफ़ॉक्स को इसके साथ शुरू करना होगा –headless झंडा इस प्रकार है -

capabilities: {
   'browserName': 'firefox',
   'moz:firefoxOptions': {
      'args': [“--headless”]
   }
},

परीक्षण के लिए कई ब्राउज़र सेट करना

हम कई ब्राउज़रों के खिलाफ भी परीक्षण कर सकते हैं। इसके लिए हमें मल्टीकैपिबिलिटी कॉन्फ़िगरेशन विकल्प का उपयोग करने की आवश्यकता है -

multiCapabilities: [{
   'browserName': 'chrome'
},{
   'browserName': 'firefox'
}]

कौन सा फ्रेमवर्क?

दो BDD (व्यवहार चालित विकास) परीक्षण चौखटे, जैस्मीन और मोचा प्रोट्रैक्टर द्वारा समर्थित हैं। दोनों चौखटे जावास्क्रिप्ट और Node.js. पर आधारित हैं सिंटैक्स, रिपोर्ट और मचान, लिखने और परीक्षण के प्रबंधन के लिए आवश्यक, इन रूपरेखाओं द्वारा प्रदान किए जाते हैं।

अगला, हम देखते हैं कि हम विभिन्न ढांचे कैसे स्थापित कर सकते हैं -

चमेली का ढाँचा

यह प्रोटेक्टर के लिए डिफ़ॉल्ट टेस्ट फ्रेमवर्क है। जब आप प्रोटेक्टर स्थापित करते हैं, तो आपको इसके साथ जैस्मीन 2.x संस्करण मिलेगा। हमें इसे अलग से स्थापित करने की आवश्यकता नहीं है।

मोचा ढाँचा

मोचा एक और जावास्क्रिप्ट परीक्षण ढांचा है जो मूल रूप से Node.js. पर चल रहा है। मोचा को हमारे परीक्षण ढांचे के रूप में उपयोग करने के लिए, हमें बीडीडी (व्यवहार चालित विकास) इंटरफेस और ची असिमेंट्स के साथ चाय अस प्रोमिस का उपयोग करने की आवश्यकता है। स्थापना निम्नलिखित आदेशों की मदद से की जा सकती है -

npm install -g mocha
npm install chai
npm install chai-as-promised

जैसा कि आप देख सकते हैं, -g विकल्प का उपयोग मोचा स्थापित करते समय किया जाता है, ऐसा इसलिए है क्योंकि हमने -g विकल्प का उपयोग करके विश्व स्तर पर प्रोट्रैक्टर स्थापित किया है। इसे स्थापित करने के बाद, हमें अपनी परीक्षण फ़ाइलों के अंदर चाय की आवश्यकता और स्थापित करने की आवश्यकता है। इसे निम्नानुसार किया जा सकता है -

var chai = require('chai');
var chaiAsPromised = require('chai-as-promised');
chai.use(chaiAsPromised);
var expect = chai.expect;

इसके बाद, हम चाय अस प्रोमाइज्ड का उपयोग इस तरह कर सकते हैं -

expect(myElement.getText()).to.eventually.equal('some text');

अब, हमें फ्रेमवर्क प्रॉपर्टी को फ्रेमवर्क जोड़कर कॉन्फिगरेशन फाइल की मोचा में सेट करना होगा: 'मोचा'। मोचा के लिए ha रिपोर्टर ’और for स्लो’ जैसे विकल्प निम्न प्रकार से विन्यास फाइल में जोड़े जा सकते हैं -

mochaOpts: {
   reporter: "spec", slow: 3000
}

ककड़ी रूपरेखा

हमारे परीक्षण ढांचे के रूप में ककड़ी का उपयोग करने के लिए, हमें इसे फ्रेमवर्क विकल्प के साथ प्रोट्रैक्टर के साथ एकीकृत करने की आवश्यकता है custom। निम्नलिखित कमांड की मदद से इंस्टॉलेशन किया जा सकता है

npm install -g cucumber
npm install --save-dev protractor-cucumber-framework

जैसा कि आप देख सकते हैं, ककड़ी को स्थापित करते समय -g विकल्प का उपयोग किया जाता है, यह इसलिए है क्योंकि हमने -g विकल्प के साथ विश्व स्तर पर प्रोटेक्टर स्थापित किया है। अगला, हमें ढांचा संपत्ति को निर्धारित करने की आवश्यकता हैcustom कॉन्फ़िगरेशन फ़ाइल को फ्रेमवर्क जोड़कर: 'कस्टम' और फ्रेमवर्कपथ: 'प्रोट्रैक्टर-ककड़ी-फ्रेमवर्क' को ककड़ीकोनफेज.जेएस नाम दिया गया है।

नीचे दिखाया गया सैंपल कोड एक बेसिक cucumberConf.js फाइल है, जिसका इस्तेमाल प्रोटेक्टर के साथ ककड़ी फीचर फाइल को चलाने के लिए किया जा सकता है -

exports.config = {
   seleniumAddress: 'http://localhost:4444/wd/hub',

   baseUrl: 'https://angularjs.org/',

   capabilities: {
      browserName:'Firefox'
   },

   framework: 'custom',

   frameworkPath: require.resolve('protractor-cucumber-framework'),

   specs: [
      './cucumber/*.feature'
   ],

   // cucumber command line options
   cucumberOpts: {
      require: ['./cucumber/*.js'],
      tags: [],
      strict: true,
      format: ["pretty"],
      'dry-run': false,
      compiler: []
   },
   onPrepare: function () {
      browser.manage().window().maximize();
   }
};