वाटर - क्विक गाइड
वातिर (रूबी में वेब अनुप्रयोग परीक्षण), जिसे "जल" के रूप में स्पष्ट किया गया है, रूबी का उपयोग करके विकसित एक खुला स्रोत उपकरण है जो किसी भी प्रोग्रामिंग भाषा में विकसित अनुप्रयोगों के अनुरूप होने वाले वेब एप्लिकेशन को स्वचालित करने में मदद करता है। वॉटिर इंस्टॉलेशन इंटरनेट एक्सप्लोरर, फ़ायरफ़ॉक्स, क्रोम, सफारी और एज के लिए समर्थित ब्राउज़र। इंस्टॉलेशन के लिए रूबीज के रूप में वाटर उपलब्ध है।
वातिर दिए गए ब्राउज़र से जुड़ जाएगा और URL खोलने, बटन पर क्लिक करने, किसी टेक्स्टबॉक्स के अंदर डेटा दर्ज करने के निर्देशों का पालन करता है जैसे कोई भी वास्तविक व्यक्ति करेगा। वशीर का उपयोग आमतौर पर RSpec, ककड़ी, आदि जैसे परीक्षण ढाँचों के साथ अपने ब्राउज़र समर्थन के लिए किया जाता है।
वातिर की विशेषताएं
वातिर सुविधाओं में समृद्ध है, जैसा कि नीचे चर्चा की गई है -
Location web elements- ऐसे विभिन्न तरीके हैं जिनसे आप ब्राउज़र के अंदर प्रदान किए गए वेब-तत्वों का पता लगा सकते हैं। ज्यादातर इस्तेमाल किए जाने वाले आईडी, वर्ग, टैग नाम, कस्टम विशेषताएँ, लेबल आदि हैं।
Taking Screenshots- वॉटरिर आपको आवश्यकता पड़ने पर किए गए परीक्षण का स्क्रीनशॉट लेने की अनुमति देता है। यह मध्यवर्ती परीक्षण का ट्रैक रखने में मदद करता है।
Page Performance- आप प्रदर्शन ऑब्जेक्ट का उपयोग करके पृष्ठ प्रदर्शन को आसानी से माप सकते हैं जिसमें प्रदर्शन, प्रदर्शन, प्रदर्शन, प्रदर्शन, प्रदर्शन । प्रदर्शन और प्रदर्शन.ऑर्गिन जैसे गुण हैं । जब आप ब्राउज़र से कनेक्ट होते हैं तो ये विवरण प्राप्त होते हैं।
Page Objects- वॉटिर में पेज ऑब्जेक्ट हमें कक्षाओं के रूप में कोड का पुन: उपयोग करने में मदद करेगा। इस सुविधा का उपयोग करके, हम किसी भी कोड को डुप्लिकेट किए बिना अपने ऐप को स्वचालित कर सकते हैं और इसे प्रबंधनीय भी बना सकते हैं।
Downloads - Watir के साथ, UI या वेबसाइट के लिए फ़ाइल डाउनलोड का परीक्षण करना आसान है।
Alerts - Watir आपके UI या वेबसाइट में अलर्ट पॉपअप का परीक्षण करने के लिए एपीआई का उपयोग करना आसान बनाता है।
Headless Testing- हेडलेस टेस्टिंग का उपयोग करते हुए, कमांड को ब्राउजर को खोले बिना कमांड लाइन में प्राप्त किया जाता है। यह कमांड लाइन पर UI परीक्षण मामलों को निष्पादित करने में मदद करता है।
पानी का उपयोग करने के लाभ
वाटरिर निम्नलिखित लाभ प्रदान करता है -
Watir एक ओपन सोर्स टूल है और उपयोग करने में बहुत आसान है।
वाटर को रूबी में विकसित किया गया है और एक ब्राउज़र में काम करने वाले किसी भी वेब एप्लिकेशन को आसानी से वॉटरर का उपयोग करके स्वचालित किया जा सकता है।
वाटरिट में सभी नवीनतम ब्राउज़रों का समर्थन किया जाता है जो परीक्षण के लिए आसान बनाते हैं।
पेज-परफॉर्मेंस, अलर्ट्स, आइफ्रेम टेस्ट, ब्राउजर विंडो, स्क्रीनशॉट्स आदि लेने के लिए वटिर में इनबिल्ट लाइब्रेरी हैं।
वतिर के नुकसान
किसी भी अन्य सॉफ्टवेयर की तरह, वातिर की भी अपनी सीमाएँ हैं
वातिर को केवल रूबी परीक्षण ढांचे के लिए समर्थित किया गया है और इसे किसी अन्य परीक्षण ढांचे के साथ उपयोग नहीं किया जा सकता है।
वॉटिर का उपयोग करके मोबाइल परीक्षण को बढ़ाया नहीं गया है और डेस्कटॉप ब्राउज़र को वास्तविक समय के उपकरणों के रूप में कार्य करने के बजाय मोबाइल ब्राउज़रों की तरह व्यवहार करने के लिए नकल की जाती है।
Watir (Web Application Testing in Ruby)"वाटर" के रूप में स्पष्ट किया गया, रूबी का उपयोग करके विकसित एक खुला स्रोत उपकरण है जो वेब अनुप्रयोग को स्वचालित करने में मदद करता है, चाहे वह जिस भी भाषा में लिखा गया हो। वातिर एपीआई के एक समृद्ध सेट के साथ आता है जो हमें ब्राउज़र के साथ बातचीत करने, पृष्ठ तत्वों का पता लगाने, स्क्रीनशॉट लेने, अलर्ट के साथ काम करने, फ़ाइल डाउनलोड करने, विंडो खोलने , पॉपअप विंडो, हेडलेस परीक्षण आदि के साथ आता है।
समर्थित ब्राउज़र हैं -
- इंटरनेट एक्स्प्लोरर
- Firefox
- Chrome
- Safari
- Edge
Note - वॉटरिर स्थापना के लिए रूबीग्मस रत्न के रूप में उपलब्ध है।
Watir webdriver का उपयोग करके, आप अपनी वेबसाइटों और UI अनुप्रयोगों का परीक्षण कर सकते हैं। जैसा कि वतिर पूरी तरह से ब्राउज़र से संबंधित सामान पर ध्यान केंद्रित करता है, आप वटीर को अन्य परीक्षण ढांचे जैसे -
- RSpec
- Cucumber
परीक्षण फ्रेमवर्क का उपयोग करके मुख्य परीक्षण कोड लिखा जाएगा और ब्राउज़र के साथ बातचीत वातिर की मदद से की जाएगी।
वातिर के साथ परीक्षण ढांचे का प्रवाह नीचे दिखाया गया है -
RSpec या ककड़ी टेस्ट रनर और टेस्ट कोड में शामिल हैं। वेबसाइट या यूआई परीक्षण के बारे में विवरण पृष्ठ ऑब्जेक्ट में टूट सकता है जिसमें वातिर का संदर्भ होगा, जिसमें इसे परीक्षण के लिए उपयोग किए जाने वाले पेज लोकेटर मिलेंगे। वातिर, अपने वेबड्राइवर के साथ, ब्राउज़र से जुड़ने और टेस्ट ऑटोमेशन को अंजाम देने में मदद करता है।
वतिर के साथ काम करने के लिए, हमें निम्नलिखित को स्थापित करना होगा -
- रूबी स्थापित करें
- वातिर स्थापित करें
- माणिक खान (आईडीई)
चूंकि वातिर रूबी का उपयोग कर निर्माण कर रहा है, हमें रूबी और मणि स्थापित करना होगा (रूबी के लिए पैकेज मैनेजर)।
विंडोज़ पर रूबी इंस्टॉलेशन
विंडोज पर रूबी स्थापित करने के लिए, - https://rubyinstaller.org/downloads/
अपने 32 या 64 बिट ऑपरेटिंग सिस्टम के आधार पर माणिक संस्करण स्थापित करें। यहाँ हमने एक हाइलाइटेड को स्थापित किया है जैसा कि स्क्रीनशॉट में दिखाया गया है। एक बार जब आप इसे डाउनलोड करते हैं, तो बताए गए चरणों का पालन करें और तदनुसार स्थापित करें।
जब आपको स्थापना के साथ किया जाता है, तो जांच लें कि क्या रूबी कमांड लाइन में संस्करण की जांच करके स्थापित किया गया है जैसा कि नीचे दिखाया गया है -
C:\> ruby -v
यदि रूबी सफलतापूर्वक स्थापित है, तो आप नीचे दिखाए अनुसार आउटपुट देख सकते हैं -
स्थापित संस्करण 2.6.3 है। हमने अपने सिस्टम पर रूबी को सफलतापूर्वक स्थापित किया है। साथ ही रूबी इंस्टॉलेशन मणि यानी माणिक पैकेज मैनेजर भी स्थापित किया गया है। आप मणि के संस्करण की जाँच निम्नानुसार कर सकते हैं -
हम खिड़कियों पर रूबी और मणि की स्थापना के साथ किया जाता है।
लिनक्स पर रूबी इंस्टॉलेशन
लिनक्स पर रूबी स्थापित करने के लिए, अपने लिनक्स टर्मिनल में निम्नलिखित कमांड चलाएं -
wget -O ruby-install-0.6.0.tar.gz https://github.com/postmodern/ruby-install/archive/v0.6.0.tar.gz
tar -xzvf ruby-install-0.6.0.tar.gz
cd ruby-install-0.6.0/
sudo make install
ruby-install ruby 2.5.3
मैक के लिए रूबी स्थापना
लिनक्स पर रूबी स्थापित करने के लिए, अपने मैक टर्मिनल में कमांड के नीचे चलाएं -
Xcode स्थापित करें
xcode-select --install
HomeBrew स्थापित करें
/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
आरबेंव स्थापित करें
brew install rbenv
rbenv init
touch ~/.bash_profile
echo 'eval "$(rbenv init -)"' >> ~/.bash_profile
source ~/.bash_profile
rbenv install 2.5.3
rbenv local 2.5.3
वतिर को स्थापित करना
वॉटिर स्थापित करने की कमान है -
gem install watir
मणि स्थापित वतीर
फिर आप नीचे दिखाए अनुसार आउटपुट स्क्रीन देख सकते हैं -
RubyMine आईडीई
हम अपने परीक्षण मामलों को लिखने और निष्पादित करने के लिए रूबीमाइन आईडीई का उपयोग करेंगे। RubyMine IDE के लिए आधिकारिक वेबसाइट www.jetbrains.com/ruby है ।
रूबीमाइन 30 दिनों के नि: शुल्क परीक्षण के साथ एक पेड आईडीई है। डाउनलोड करने के लिए नि: शुल्क परीक्षण बटन पर क्लिक करें। आप परीक्षण-मामलों को लिखने के लिए अपनी पसंद के कुछ अन्य आईडीई का उपयोग भी कर सकते हैं।
नि: शुल्क परीक्षण बटन पर क्लिक करने पर यह डाउनलोड होना शुरू हो जाएगा। डाउनलोड हो जाने के बाद, इसे अपने सिस्टम पर स्थापित करें।
अगला पर क्लिक करें और स्थापना के साथ आगे बढ़ें। एक बार इंस्टॉलेशन पूरा हो जाने के बाद, आईडीई खोलें और यह आपको प्रोजेक्ट बनाने के लिए कहेगा जैसा कि नीचे दिखाया गया है -
Create New Project पर क्लिक करें, हमने प्रोजेक्ट का नाम Watir के रूप में दर्ज किया है और यहाँ IDE में डिस्प्ले है -
हम वियर / फोल्डर में अपने टेस्ट-केस लिखेंगे और उसे निष्पादित करेंगे।
इस अध्याय में, हम उन ब्राउज़र ड्राइवरों को स्थापित करने जा रहे हैं, जिन्हें हमें वाटरर का उपयोग करके अपनी परियोजना का परीक्षण करने की आवश्यकता है। Watir 6 से पहले, हमें ब्राउज़र ड्राइवरों का उपयोग करने के लिए वॉटिर-वेबड्राइवर को शामिल करना था । Watir 6 की रिलीज़ के साथ, वॉटर-वेबड्राइवर Watir पैकेज के हिस्से के रूप में उपलब्ध है और उपयोगकर्ताओं को वॉटर-वेबड्राइवर को अलग से जोड़ना नहीं पड़ता है ।
क्रोम, फ़ायरफ़ॉक्स और सफारी जैसे ब्राउज़र डिफ़ॉल्ट रूप से उपलब्ध हैं और आपको उन्हें बाहरी रूप से जोड़ना नहीं है। परीक्षण करते समय आप एक समस्या प्राप्त करें कि ब्राउज़र के लिए ड्राइवर उपलब्ध नहीं है, आप हमेशा उन्हें नीचे दिए गए निर्देशों के अनुसार डाउनलोड कर सकते हैं।
हम निम्नलिखित ब्राउज़रों के लिए ड्राइवर स्थापित करने जा रहे हैं -
- ब्राउजर के लिए ड्राइवर - क्रोम
- ब्राउजर के लिए ड्राइवर - फ़ायरफ़ॉक्स
- ब्राउजर के लिए ड्राइवर - एज
- ब्राउजर के लिए ड्राइवर - इंटरनेट एक्सप्लोरर
- ड्राइवर फॉर ब्राउजर - सफारी
ब्राउज़र के लिए ड्राइवर - क्रोम
क्रोम ब्राउज़र के लिए ड्राइवर प्राप्त करने के लिए, - https://sites.google.com/a/chromium.org/chromedriver/downloads।
अपने ब्राउज़र के संस्करण की जाँच करें और तदनुसार क्रोम चालक डाउनलोड करें। अपने क्रोम ब्राउज़र के संस्करण की जाँच करने के लिए, जैसा कि यहाँ दिखाया गया है -
Google Chrome के बारे में क्लिक करें और यह आपको नीचे दिखाए गए अनुसार क्रोम संस्करण देगा -
तो हमारा संस्करण 74 है। इसलिए, क्रोम चालक संस्करण 74 डाउनलोड करें।
अगला, अपने ऑपरेटिंग सिस्टम के आधार पर क्रोम ड्राइवर डाउनलोड करें। हम chromedriver_win32.zip डाउनलोड करेंगे, यह 32-बिट और 64-बिट मशीनों दोनों के लिए है। यदि आप डाउनलोड किए गए ड्राइवर का उपयोग करने की योजना बना रहे हैं, तो अपने पेटीएम चर पर कहीं और स्थान जोड़ें।
ब्राउज़र के लिए ड्राइवर - फ़ायरफ़ॉक्स
फ़ायरफ़ॉक्स चालक के लिए, पर जाएं - https://github.com/mozilla/geckodriver/releases जैसा कि नीचे स्क्रीनशॉट में दिखाया गया है -
अपने ऑपरेटिंग सिस्टम के अनुसार, ड्राइवर को ऊपर दिखाए अनुसार डाउनलोड करें। यदि आप डाउनलोड किए गए ड्राइवर का उपयोग करने की योजना बना रहे हैं, तो अपने पैट वैरिएबल पर कहीं और स्थान जोड़ें।
ब्राउज़र के लिए ड्राइवर - एज
फ़ायरफ़ॉक्स चालक के लिए, पर जाएं - https://developer.microsoft.com/en-us/microsoft-edge/tools/webdriver/ जैसा कि नीचे स्क्रीनशॉट में दिखाया गया है -
Microsoft एज के संस्करण पर क्लिक करें जो आपने नीचे दिखाया है -
रिलीज़ लिंक पर क्लिक करें और यह आपको -
यहां, आप विंडोज़ के लिए उपलब्ध डाउनलोड संस्करण पा सकते हैं। यदि आप डाउनलोड किए गए ड्राइवर का उपयोग करने की योजना बना रहे हैं, तो अपने पेटीएम चर पर कहीं और स्थान जोड़ें।
ब्राउज़र के लिए ड्राइवर - इंटरनेट एक्सप्लोरर
Internet Explorer के लिए ड्राइवर स्थापित करने के लिए निम्न पर जाएं - https://docs.seleniumhq.org/download/ जैसा कि नीचे दिखाया गया है -
IE पर डाउनलोड अनुभाग के लिए विवरण यहाँ दिखाए गए हैं -
अपने OS के अनुसार, 32 या 64 बिट विंडोज़ IE डाउनलोड करें। ड्राइवर का उपयोग करने के लिए स्थान को भी आप को पाथ चर में जोड़ें।
ड्राइवर्स के लिए ड्राइवर्स - सफारी
सफारी के लिए ड्राइवरों को सफारी संस्करण 10 के लिए बाहरी रूप से डाउनलोड करने की आवश्यकता नहीं है। Watir को स्थापित करते समय उन्हें रत्न पैकेज के साथ डाउनलोड किया जाता है।
कृपया ध्यान दें कि Watir स्थापित होने पर Chrome, Firefox, Internet Explorer के ड्राइवर भी उपलब्ध हैं। लेकिन अगर आप किसी भी समस्या का सामना करते हैं और परीक्षण किए जाने के लिए एक विशिष्ट संस्करण की आवश्यकता है, तो आप इसे अपने ब्राउज़र के अनुसार डाउनलोड कर सकते हैं और अपने आवेदन के परीक्षण में इसका उपयोग करने के लिए पेट में स्थान को अपडेट कर सकते हैं।
डिफ़ॉल्ट रूप से, Watir ब्राउज़र का नाम निर्दिष्ट नहीं करने पर क्रोम ब्राउज़र खोल देगा। आवश्यक ब्राउज़र ड्राइवर वाटर इंस्टॉलेशन के साथ इंस्टॉल किए जाते हैं। यदि आप ब्राउज़रों के साथ काम करने में किसी भी समस्या का सामना करते हैं, तो ड्राइवर को स्थापित करें जैसा कि ब्राउज़र ड्राइवरों के अध्याय में दिखाया गया है और पीएटीएच चर में स्थान को अपडेट करता है।
इस अध्याय में, हम समझेंगे कि वॉटिर का उपयोग करके ब्राउज़र कैसे खोलें।
वाटर का उपयोग करके एक ब्राउज़र खोलने के लिए कदम
IDE RubyMine खोलें और एक नई फ़ाइल बनाएं: test1.rb
ठीक का चयन करें और नीचे दिखाए अनुसार रूबी के रूप में फ़ाइल पैटर्न पर क्लिक करें -
फ़ाइल बनाने के लिए ओके पर क्लिक करें।
अब हम एक सरल कोड लिखेंगे जो नीचे दिखाए गए ब्राउज़र को खोलेगा -
test1.rb
require 'watir'
Watir::Browser.new
ऊपर दिखाए गए अनुसार IDE में हाइलाइट किए गए रन बटन पर क्लिक करें। रन पर क्लिक करने पर, यह नीचे दिखाए गए अनुसार ब्राउज़र खोलेगा -
ब्राउज़र अपने आप खुल जाएगा और बंद हो जाएगा। चलिए अब test1.rb में कुछ और कोड जोड़ते हैं।
हम नीचे दिखाए गए अनुसार ब्राउज़र का नाम निर्दिष्ट कर सकते हैं -
क्रोम के लिए उदाहरण
require 'watir'
Watir::Browser.new :chrome
अब हम अपने परीक्षण के मामले में एक पेज-यूआरएल खोलें।
उदाहरण
require 'watir'
browser = Watir::Browser.new
browser.goto("https://www.google.com")
नीचे दिखाए अनुसार रन देखने के लिए रन पर क्लिक करें -
इसी तरह, आप फ़ायरफ़ॉक्स, सफारी, इंटरनेट एक्सप्लोरर ब्राउज़र खोल सकते हैं।
फ़ायरफ़ॉक्स के लिए उदाहरण
require 'watir'
Watir::Browser.new :firefox
इंटरनेट एक्सप्लोरर के लिए उदाहरण
Watir Code
require 'watir'
browser = Watir::Browser.new :ie
browser.goto("https://www.google.com")
जब हम कोड चलाते हैं तो निम्नलिखित त्रुटि प्रदर्शित होती है -
Unable to find IEDriverServer. Please download the server from
(Selenium::WebDriver::Error::WebDriverError)
http://selenium-release.storage.googleapis.com/index.html and place it
somewhere on your PATH.
More info at
https://github.com/SeleniumHQ/selenium/wiki/InternetExplorerDriver.
इसका मतलब यह है कि वॉटिर पैकेज में InternetExplorer ड्राइवर नहीं है। हमने यहाँ से वही डाउनलोड किया है -https://docs.seleniumhq.org/download/ और पथ चर में अद्यतन किया गया।
अब इसे फिर से चलाने के लिए इंटरनेट एक्सप्लोरर ब्राउज़र को खोलें जैसा कि नीचे दिखाया गया है -
सफ़ारी ब्राउज़र खोलने के लिए वॉटर कोड
require 'watir'
browser = Watir::Browser.new :safari
browser.goto("https://www.google.com")
Microsoft एज ब्राउजर के लिए वातिर कोड
require 'watir'
browser = Watir::Browser.new :edge
browser.goto("https://www.google.com")
इस अध्याय में, हम चर्चा करेंगे कि वातिर में निम्नलिखित कार्य कैसे करें -
- टेक्स्टबॉक्स के साथ काम करना
- कंबोज के साथ काम करना
- रेडियो बटन के साथ काम करना
- चेकबॉक्स के साथ काम करना
- बटन के साथ काम करना
- लिंक्स के साथ काम करना
- दिव्यांगों के साथ काम करना
टेक्स्टबॉक्स के साथ काम करना
वाक्य - विन्यास
browser.text_field id: 'firstname' // will get the reference of the textbox
यहां समझने की कोशिश करेंगे कि UI पर टेक्स्टबॉक्स के साथ कैसे काम किया जाए।
नीचे दिखाए गए अनुसार टेक्स्टबॉक्स पेज पर विचार करें -
<html>
<head>
<title>Testing UI using Watir</title>
</head>
<body>
<script type = "text/javascript">
function wsentered() {
console.log("inside wsentered");
var firstname = document.getElementById("firstname");
if (firstname.value != "") {
document.getElementById("displayfirstname").innerHTML =
"The name entered is : " + firstname.value;
document.getElementById("displayfirstname").style.display = "";
}
}
</script>
<div id = "divfirstname">
Enter First Name :
<input type = "text" id = "firstname" name = "firstname" onchange = "wsentered()" />
</div>
<br/>
<br/>
<div style = "display:none;" id = "displayfirstname"></div>
</body>
</html>
इसी आउटपुट को नीचे दिखाया गया है -
हमारे पास एक टेक्स्टबॉक्स है, जब आप नाम दर्ज करते हैं, तो ऑन्चेंज इवेंट को निकाल दिया जाता है और नाम नीचे प्रदर्शित किया जाता है।
अब हम कोड लिखते हैं, जिसमें हम टेक्स्टबॉक्स का पता लगाएंगे और नाम दर्ज करेंगे और ऑन्चेंज इवेंट को फायर करेंगे।
वातिर कोड
require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/textbox.html')
t = b.text_field id: 'firstname'
t.exists?
t.set 'Riya Kapoor'
t.value
t.fire_event('onchange')
हम क्रोम ब्राउजर का उपयोग कर रहे हैं और पेजरेल को दिया गया है http://localhost/uitesting/textbox.html।
गोटो एपि ब्राउजर का उपयोग करने से पेजरल खुल जाएगा और हम text_field id: firstname ढूंढने जा रहे हैं। यदि यह मौजूद है, तो हम रिया कपूर के रूप में मूल्य निर्धारित करेंगे और ऑनकेंज इवेंट को फायर करने के लिए fire_event एपीआई का उपयोग करेंगे ।
अब, नीचे दिए गए आउटपुट को प्रदर्शित करने के लिए कोड चलाते हैं -
कंबोज के साथ काम करना
वाक्य - विन्यास
browser.select_list id: 'months' // will get the reference of the dropdown
अब हम जिस परीक्षण पृष्ठ पर परीक्षण करने जा रहे हैं, वह यहाँ दिखाया गया है -
<html>
<head>
<title>Dropdown</title>
</head>
<body>
<script type = "text/javascript">
function wsselected() {
var months = document.getElementById("months");
if (months.value != "") {
document.getElementById("displayselectedmonth").innerHTML =
"The month selected is : " + months.value;
document.getElementById("displayselectedmonth").style.display = "";
}
}
</script>
<form name = "myform" method = "POST">
<div>
Month is :
<select name = "months" id = "months" onchange = "wsselected()">
<option value = "">Select Month</option>
<option value = "Jan">January</option>
<option value = "Feb">February</option>
<option value = "Mar">March</option>
<option value = "Apr">April</option>
<option value = "May">May</option>
<option value = "Jun">June</option>
<option value = "Jul">July</option>
<option value = "Aug">August</option>
<option value = "Sept">September</option>
<option value = "Oct">October</option>
<option value = "Nov">November</option>
<option value = "Dec">December</option>
</select>
</div>
<br/>
<br/>
<div style = "display:none;" id = "displayselectedmonth">
</div>
</body>
</html>
उत्पादन
जब आप ड्रॉपडाउन से महीने का चयन करते हैं तो नीचे प्रदर्शित किया जाता है।
आइए अब हम वतिर का उपयोग करके उसी का परीक्षण करते हैं।
कॉम्बो चयन के लिए वाटर कोड
require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/combos.html')
t = b.select_list id: 'months'
t.exists?
t.select 'September'
t.selected_options
t.fire_event('onchange')
कोम्बोस के साथ काम करने के लिए, आपको ड्रॉपडाउन की आईडी के बाद b.select_list api का उपयोग करके चुनिंदा तत्व का पता लगाना होगा। ड्रॉपडाउन से मूल्य का चयन करने के लिए, आपको t.select और इच्छित मान का उपयोग करने की आवश्यकता है।
निष्पादन पर आउटपुट निम्नानुसार है -
रेडियो बटन के साथ काम करना
वाक्य - विन्यास
browser.radio value: 'female'
// will get the reference of the radio button with value “female”
यहाँ एक परीक्षण पृष्ठ है जिसका उपयोग हम रेडियो बटन के साथ करने के लिए करेंगे -
<html>
<head>
<title>Testing UI using Watir</title>
</head>
<body>
<form name = "myform" method = "POST">
<b>Select Gender?</b>
<div>
<br/>
<input type = "radio" name = "gender" value = "male" checked> Male
<br/>
<input type = "radio" name = "gender" value = "female"> Female
<br/>
</div>
</form>
</body>
</html>
हम वियर कोड में दिखाए गए मान के साथ रेडियो बटन का चयन करेंगे -
require 'watir'
b = Watir::Browser.new
b.goto('http://localhost/uitesting/radiobutton.html')
t = b.radio value: 'female'
t.exists?
t.set
b.screenshot.save 'radiobutton.png'
रेडियो बटन के साथ काम करने के लिए, हमें ब्राउज़र को उस मूल्य के बारे में बताना होगा जिसे हम चुन रहे हैं b.radio value:”female”
हम स्क्रीनशॉट भी ले रहे हैं और सहेजा हुआ है कि जैसा कि radiobutton.png और उसी को नीचे प्रदर्शित किया गया है -
चेकबॉक्स के साथ काम करना
वाक्य - विन्यास
browser. checkbox value: 'Train'
// will get the reference of the checkbox with value “Train”
यहाँ चेकबॉक्स के लिए परीक्षण पृष्ठ है -
<html>
<head>
<title>Testing UI using Watir</title>
</head>
<body>
<form name = "myform" method = "POST">
<b>How would you like to travel?</b>
<div>
<br>
<input type = "checkbox" name = "option1" value = "Car"> Car<br>
<input type = "checkbox" name = "option2" value = "Bus"> Bus<br>
<input type = "checkbox" name = "option3" value = "Train"> Train<br>
<input type = "checkbox" name = "option4" value = "Air"> Airways<br>
<br>
</div>
</form>
</body>
</html>
अब, हमें नीचे दिखाए गए अनुसार ब्राउजर में चेकबॉक्स का पता लगाने के लिए वॉटिर का उपयोग करें -
require 'watir'
b = Watir::Browser.new
b.goto('http://localhost/uitesting/checkbox.html')
t = b.checkbox value: 'Train'
t.exists?
t.set
b.screenshot.save 'checkbox.png'
ब्राउज़र में चेकबॉक्स का पता लगाने के लिए, उस मूल्य के साथ b.checkbox का उपयोग करें जिसका आप चयन करना चाहते हैं।
बटन के साथ काम करना
वाक्य - विन्यास
browser.button(:name => "btnsubmit").click
// will get the reference to the button element with has name “btnsubmit”
यहाँ बटन के लिए परीक्षण पृष्ठ है -
<html>
<head>
<title>Testing UI using Watir</title>
</head>
<body>
<script type = "text/javascript">
function wsclick() {
document.getElementById("buttondisplay").innerHTML = "Button is clicked";
document.getElementById("buttondisplay").style.display = "";
}
</script>
<form name = "myform" method = "POST">
<div>
<br>
<input type = "button" id = "btnsubmit" name = "btnsubmit"
value = "submit" onclick = "wsclick()"/>
<br>
</div>
</form>
<br/>
<div style = "display:none;" id = "buttondisplay"></div>
</body>
</html>
यहाँ दिए गए पृष्ठ पर बटन का पता लगाने के लिए वशीर कोड है -
require 'watir'
b = Watir::Browser.new
b.goto('http://localhost/uitesting/button.html')
b.button(:name => "btnsubmit").click
b.screenshot.save 'button.png'
यहाँ स्क्रीनशॉट बटन है। पीएनजी
लिंक्स के साथ काम करना
वाक्य - विन्यास
browser.link text: 'Click Here'
// will get the reference to the a tag with text ‘Click Here’
हम लिंक का परीक्षण करने के लिए निम्नलिखित परीक्षण पृष्ठ का उपयोग करने जा रहे हैं -
<html>
<head>
<title>Testing UI using Watir</title>
</head>
<body>
<br/>
<br/>
<a href = "https://www.google.com">Click Here</a>
<br/>
</body>
</html>
लिंक का परीक्षण करने के लिए आवश्यक विवरण नीचे दिए गए हैं -
require 'watir'
b = Watir::Browser.new
b.goto('http://localhost/uitesting/links.html')
l = b.link text: 'Click Here'
l.click
b.screenshot.save 'links.png'
उत्पादन
दिव्यांगों के साथ काम करना
वाक्य - विन्यास
browser.div class: 'divtag'
// will get the reference to div with class “divtag”
परीक्षण पृष्ठ जहां हम div के लिए परीक्षण कर सकते हैं।
<html>
<head>
<title>Testing UI using Watir</title>
<style>
.divtag {
color: blue;
font-size: 25px;
}
</style>
</head>
<body>
<br/>
<br/>
<div class = "divtag"> UI Testing using Watir </div>
<br/>
</body>
</html>
उत्पादन
Div का परीक्षण करने के लिए वाटर कोड यहाँ दिखाया गया है -
require 'watir'
b = Watir::Browser.new
b.goto('http://localhost/uitesting/div.html')
l = b.div class: 'divtag'
l.exists?
l.text
b.screenshot.save 'divtag.png'
उत्पादन
परीक्षण के लिए वाटर में, आपको तत्वों का पता लगाने की आवश्यकता है और इसे विभिन्न तरीकों से किया जा सकता है - तत्व की आईडी, कक्षा या पाठ का उपयोग करके।
इस अध्याय में, हम कुछ उदाहरण देखेंगे जो तत्वों का पता लगाने के विभिन्न तरीके दिखाते हैं।
तत्व की आईडी का उपयोग करना
परीक्षण पृष्ठ
<html>
<head>
<title>Testing UI using Watir</title>
</head>
<body>
<script type = "text/javascript">
function wsentered() {
console.log("inside wsentered");
var firstname = document.getElementById("firstname");
if (firstname.value != "") {
document.getElementById("displayfirstname").innerHTML =
"The name entered is : " + firstname.value;
document.getElementById("displayfirstname").style.display = "";
}
}
</script>
<div id = "divfirstname">
Enter First Name :
<input type = "text" id = "firstname" name = "firstname" onchange = "wsentered()" />
</div>
<br/>
<br/>
<div style = "display:none;" id = "displayfirstname">
</div>
</body>
</html>
उदाहरण
require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/textbox.html')
t = b.text_field(id: 'firstname') // using the id of the textbox to locate the textbox
t.exists?
t.set 'Riya Kapoor'
b.screenshot.save 'textboxbefore.png'
t.value
t.fire_event('onchange')
b.screenshot.save 'textboxafter.png'
इस उदाहरण में, हम इसे खोजने और मान सेट करने के लिए टेक्स्टबॉक्स तत्व की आईडी का उपयोग कर रहे हैं।
t = b.text_field(id: 'firstname')
उत्पादन
यदि आपको div, span या किसी अन्य html टैग का पता लगाने की आवश्यकता है, तो आप निम्नानुसार आईडी का उपयोग कर सकते हैं -
डिव के लिए
browser.div(id: "divid")
browser.div(id: /divid/)
स्पान के लिए
browser.span(id: "spanid")
browser.span(id: /spanid/)
तत्व का नाम का उपयोग करना
परीक्षण पृष्ठ
<html>
<head>
<title>Testing UI using Watir</title>
</head>
<body>
<script type = "text/javascript">
function wsentered() {
console.log("inside wsentered");
var firstname = document.getElementById("firstname");
if (firstname.value != "") {
document.getElementById("displayfirstname").innerHTML =
"The name entered is : " + firstname.value;
document.getElementById("displayfirstname").style.display = "";
}
}
</script>
<div id = "divfirstname">
Enter First Name :
<input type = "text" id = "firstname" name = "firstname" onchange = "wsentered()" />
</div>
<br/>
<br/>
<div style = "display:none;" id = "displayfirstname">
</div>
</body>
</html>
उदाहरण
require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/textbox.html')
t = b.text_field(name: 'firstname') // name is used to locate the textbox element
t.exists?
t.set 'Riya Kapoor'
b.screenshot.save 'textboxbefore.png'
t.value
t.fire_event('onchange')
b.screenshot.save 'textboxafter.png'
उत्पादन
टैग नाम का उपयोग करना
आप नीचे दिखाए गए अनुसार HTML टैग का उपयोग करके सीधे अपने इच्छित किसी भी HTML तत्वों का पता लगा सकते हैं।
डिव के लिए
browser.div(id: "divid")
browser.div(id: /divid/)
स्पान के लिए
browser.span(id: "spanid")
browser.span(id: /spanid/)
पी टैग के लिए
browser.p(id: "ptag")
browser.p(id: /ptag/)
बटन के लिए
browser.button(id: "btnid")
browser.button(id: /btnid/)
कक्षा के नाम का उपयोग करना
आप इसके क्लासनाम का उपयोग करके तत्व का पता लगा सकते हैं। इसे नीचे दिखाए अनुसार किया जा सकता है -
डिव के लिए
browser.div(class: "divclassname")
browser.div(class: /divclassname/)
स्पान के लिए
browser.span(class: "spanclassname”)
browser.span(class: /spanclassname/)
पी टैग के लिए
browser.p(class: "pclassname")
browser.p(class: /pclassname/)
बटन के लिए
browser.button(class: "btnclassname")
browser.button(class: /btnclassname/)
टेक्स्टबॉक्स के लिए
browser.text_field(class: 'txtclassname')
browser.text_field(class: /txtclassname/)
आप नीचे दिखाए गए अनुसार कई कक्षाएं भी पास कर सकते हैं -
डिव के लिए
browser.div(class: ["class1", "class2"])
पाठ का उपयोग करना
यह एक पाठ के साथ तत्वों का उपयोग करके तत्वों का पता लगाने का एक और तरीका है। उदाहरण के लिए -
browser.button(text: "button text")
browser.button(text: /button text/)
लेबल का उपयोग करना
आप नीचे दिखाए गए अनुसार इसे खोजने के लिए तत्व के लेबल का उपयोग कर सकते हैं -
browser.text_field(label: "text here"))
browser.text_field(label: /text here/))
डेटा विशेषताओं का उपयोग करना
यदि आपके पास अपने HTML टैग में डेटा विशेषताएँ हैं, तो आप नीचे दिखाए गए अनुसार इसका उपयोग करने वाले तत्वों का पता लगा सकते हैं -
उदाहरण के लिए, आप नीचे दिखाए गए टैग का पता लगा सकते हैं -
<div data-type = "test1"></div>
आप निम्नानुसार div का पता लगा सकते हैं -
browser.div(data-type: 'test1'))
browser.div(data-type: /test1/))
कस्टम विशेषता का उपयोग करना
आप नीचे दिखाए गए अनुसार कस्टम विशेषताओं का उपयोग करने वाले तत्वों का भी पता लगा सकते हैं -
Html एलिमेंट का उदाहरण
<div itemprop = ”content”>
….
</div>
आप निम्नानुसार div का पता लगा सकते हैं -
browser.div(itemprop: ‘content'))
browser.div(itemprop: /content/))
दर्शनीय विशेषता का उपयोग करना
दृश्य विशेषता का उपयोग करने वाला तत्व नीचे दिखाया गया है -
browser.div(visible: true)
browser.div(visible: false)
वॉटरिर इफ्रेम के साथ काम करने के लिए सिंटैक्स का उपयोग करने के लिए आसान प्रदान करता है।
वाक्य - विन्यास
browser.iframe(id: 'myiframe')
// will get the reference of the iframe where we want to input details.
यह समझने के लिए कि आइफ्रेम से कैसे निपटा जाए और एक आइफ्रेम के अंदर के तत्वों का पता लगाएं, इस अध्याय में, हम एक उदाहरण पर काम करेंगे।
उदाहरण
main.html
<html>
<head>
<title>Testing using Watir</title>
</head>
<body>
<iframe src = "test1.html" id = "myiframe" width = "500" height = "100"></iframe>
</body>
</html>
test1.html
<html>
<head>
<title>Testing UI using Watir</title>
</head>
<body>
<script type = "text/javascript">
function wsentered() {
console.log("inside wsentered");
var firstname = document.getElementById("firstname");
if (firstname.value != "") {
document.getElementById("displayfirstname").innerHTML =
"The name entered is : " + firstname.value;
document.getElementById("displayfirstname").style.display = "";
}
}
</script>
<div id = "divfirstname">
Enter First Name :
<input type = "text" id = "firstname" name = "firstname" onchange = "wsentered()" />
</div>
<br/>
<br/>
<div style = "display:none;" id = "displayfirstname"></div>
</body>
</html>
उत्पादन
उपरोक्त उदाहरण में, प्रवेश फॉर्म एक iframe के अंदर परिभाषित किया गया है। वॉटिर कोड जो हमें इसका पता लगाने और फॉर्म का परीक्षण करने में मदद करेगा नीचे दिया गया है -
वातिर कोड
require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/main.html')
t = b.iframe(id: 'myiframe').text_field
t.set 'Riya Kapoor'
b.screenshot.save 'iframetestbefore.png'
t.fire_event('onchange')
b.screenshot.save 'iframetestafter.png'
यहां दिए गए url में iframe का पता लगाने के लिए वातिर कोड -
t = b.iframe(id: 'myiframe').text_field
हमने टैग नाम iframe और iframe की आईडी का उपयोग ऊपर दिखाया गया है।
उपरोक्त कोड के स्क्रीनशॉट नीचे दिखाए गए हैं -
iframetestbefore.png
iframetestafter.png
इस अध्याय में, आइए हम विस्तार से इंतजार करते हैं। स्वचालित प्रतीक्षा को समझने के लिए, हमने एक साधारण परीक्षण पृष्ठ बनाया है। जब उपयोगकर्ता टेक्स्टबॉक्स में पाठ दर्ज करता है onchange घटना को निकाल दिया जाता है और 3-सेकंड के बाद बटन को सक्षम किया जाता है।
वतिर के पास एक वाट्सएप एप कॉल है जो किसी विशेष घटना या संपत्ति पर इंतजार करता है। हम नीचे दिए गए परीक्षण पृष्ठ के लिए उसी तरह का परीक्षण करेंगे -
वाक्य - विन्यास
browser.button(id: 'btnsubmit').wait_until(&:enabled?)
//here the wait is on the button with id : btnsubmit to be enabled.
testwait.html
<html>
<head>
<title>Testing UI using Watir</title>
</head>
<body>
<script type = "text/javascript">
function wsentered() {
setTimeout(function() {
document.getElementById("btnsubmit").disabled = false; }, 3000);
}
function wsformsubmitted() {
document.getElementById("showmessage").style.display = "";
}
</script>
<div id = "divfirstname">
Enter First Name :
<input type = "text" id = "firstname" name = "firstname" onchange = "wsentered()" />
</div>
<br/>
<br/>
<button id = "btnsubmit" disabled onclick = "wsformsubmitted();">Submit</button>
<br/<
<br/<
<div id = "showmessage" style = "display:none;color:green;font-size:25px;">l;
Button is clicked
</div>
</body>
</html>
उत्पादन
जब आप टेक्स्ट बॉक्स में टेक्स्ट दर्ज करते हैं, तो आपको बटन को सक्षम होने के लिए 3 सेकंड तक इंतजार करना होगा।
जब आप सबमिट बटन पर क्लिक करते हैं, तो निम्न पाठ प्रदर्शित होता है -
अब चूंकि हमने बटन को सक्षम करने के लिए देरी जोड़ दी है, इसलिए स्वचालन के लिए ऐसे मामलों को संभालना मुश्किल है। जब भी हमें कुछ देरी होती है या स्थित होने की तत्व की किसी घटना या संपत्ति पर इंतजार करना पड़ता है, तो हम नीचे दिखाए अनुसार Wait_until का उपयोग कर सकते हैं -
वाट्स_ंटिल का उपयोग करके वातीर कोड
require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/testwait.html')
t = b.text_field(name: 'firstname')
t.exists?
t.set 'Riya Kapoor'
b.screenshot.save 'waittestbefore.png'
t.value
t.fire_event('onchange')
btn = b.button(id: 'btnsubmit').wait_until(&:enabled?)
btn.fire_event('onclick');
b.screenshot.save 'waittestafter.png'
अगला, निम्नलिखित कमांड का उपयोग करें
btn = b.button(id: 'btnsubmit').wait_until(&:enabled?)
वटिर बटन सक्षम होने का इंतजार करने वाला है और बाद में क्लिक इवेंट के लिए निकाल दिया जाएगा। कैप्चर किए गए स्क्रीनशॉट नीचे दिखाए गए हैं -
Waittestbefore.png
waittestafter.png
इस अध्याय में, हम यह जानेंगे कि पृष्ठ url का परीक्षण करने के लिए वतिर वेबड्राइव के हेडलेस विकल्प का उपयोग कैसे करें।
वाक्य - विन्यास
Browser = Watir::Browser.new :chrome, headless: true
जिस परीक्षण पृष्ठ पर हम परीक्षण करने जा रहे हैं वह यहाँ दिखाया गया है -
<html>
<head>
<title>Testing UI using Watir</title>
</head>
<body>
<script type = "text/javascript">
function wsentered() {
console.log("inside wsentered");
var firstname = document.getElementById("firstname");
if (firstname.value != "") {
document.getElementById("displayfirstname").innerHTML =
"The name entered is : " + firstname.value;
document.getElementById("displayfirstname").style.display = "";
}
}
</script>
<div id = "divfirstname">
Enter First Name : <input type = "text" id = "firstname" name = "firstname" onchange = "wsentered()" />
</div>
<br/>
<br/>
<div style = "display:none;" id = "displayfirstname"></div>
</body>
</html>
उत्पादन
वातिर कोड
require 'watir'
b = Watir::Browser.new :chrome, headless: true
b.goto('http://localhost/uitesting/textbox.html')
t = b.text_field(name: 'firstname')
t.exists?
t.set 'Riya Kapoor'
t.value
t.fire_event('onchange')
b.screenshot.save 'headless.png'
हमने विकल्प को बिना शीर्षक के जोड़ा है : वॉटिर क्रोम ब्राउज़र के लिए सही। जब आप रूबी प्रोग्राम निष्पादित करते हैं, तो यह ब्राउज़र को नहीं खोलेगा, सब कुछ कमांड लाइन में निष्पादित हो जाएगा -
DevTools listening on ws://127.0.0.1:53973/devtools/browser/b4127866-afb8-4c74-b967-5bacb3354b19
[0505/144843.905:INFO:CONSOLE(8)] "inside wsentered", source: http://localhost/uitesting/textbox.html (8)
हमने कंसोल.लॉग मैसेज और उसी को कमांड लाइन में प्रिंट किया है।
Headless.png का स्क्रीनशॉट नीचे दिखाया गया है -
फ़ायरफ़ॉक्स में
फ़ायरफ़ॉक्स के लिए वियर कोड यहाँ दिखाया गया है -
require 'watir'
b = Watir::Browser.new :firefox, headless: true
b.goto('http://localhost/uitesting/textbox.html')
t = b.text_field(name: 'firstname')
t.exists?
t.set 'Riya Kapoor'
t.value
t.fire_event('onchange')
b.screenshot.save 'headlessfirefox.png'
हेडलेसफ़ायरफ़ॉक्स। पीएनजी का स्क्रीनशॉट यहाँ दिखाया गया है -
मोबाइल परीक्षण के लिए, हम डेस्कटॉप ब्राउज़र का उपयोग करने जा रहे हैं जो परीक्षण उद्देश्य के लिए डिवाइस ब्राउज़र के रूप में कार्य करेगा। आइए इस अध्याय में इसकी प्रक्रिया को समझते हैं।
मोबाइल ब्राउज़र पर अपने ऐप का परीक्षण करने के लिए हमें वेबड्राइवर-यूज़र-एजेंट को इंस्टॉल करना होगा।
Webdriver-user-Agent को स्थापित करना
gem install webdriver-user-agent
अब, हम नीचे दिए गए उदाहरण में दिखाए गए अनुसार Webdriver useragent का उपयोग करने जा रहे हैं -
उदाहरण
require 'watir'
require 'webdriver-user-agent'
driver = Webdriver::UserAgent.driver(browser: :chrome, agent: :iphone, orientation: :landscape)
browser = Watir::Browser.new driver
browser.goto 'https://facebook.com'
puts "#{browser.url}"
puts browser.url == 'https://m.facebook.com/'
हमने facebook.com url दिया है। जब आप इसे निष्पादित करते हैं, तो यह उपयोगकर्ता के आधार पर मोबाइल मोड में खुलता है, जैसा कि नीचे दिखाया गया है -
अब हम पोर्ट्रेट मोड में प्रयास करते हैं। इस उद्देश्य के लिए निम्नलिखित कोड का उपयोग करें -
require 'watir'
require 'webdriver-user-agent'
driver = Webdriver::UserAgent.driver(browser: :chrome, agent: :iphone, orientation: :portrait)
browser = Watir::Browser.new driver
browser.goto 'https://facebook.com'
puts "#{browser.url}"
puts browser.url == 'https://m.facebook.com/'
पोर्ट्रेट मोड में आउटपुट नीचे दिखाया गया है -
स्क्रीनशॉट पर कब्जा करने की क्षमता वॉटिर के साथ उपलब्ध दिलचस्प विशेषताओं में से एक है। परीक्षण स्वचालन के दौरान, आप स्क्रीनशॉट ले सकते हैं और स्क्रीन को बचा सकते हैं। मामले में, यदि कोई त्रुटि होती है, तो स्क्रीनशॉट की मदद से उसी को प्रलेखित किया जा सकता है।
परीक्षण पृष्ठ के साथ एक सरल उदाहरण जहां हमने स्क्रीनशॉट लिया है, नीचे चर्चा की गई है -
वाक्य - विन्यास
browser.screenshot.save 'nameofimage.png'
परीक्षण पृष्ठ
<html>
<head>
<title>Testing UI using Watir</title>
</head>
<body>
<script type = "text/javascript">
function wsentered() {
console.log("inside wsentered");
var firstname = document.getElementById("firstname");
if (firstname.value != "") {
document.getElementById("displayfirstname").innerHTML =
"The name entered is : " + firstname.value;
document.getElementById("displayfirstname").style.display = "";
}
}
</script>
<div id = "divfirstname">
Enter First Name :
<input type = "text" id = "firstname" name = "firstname" onchange = "wsentered()" />
</div>
<br/>
<br/>
<div style = "display:none;" id = "displayfirstname"></div>
</body>
</html>
उदाहरण
require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/textbox.html')
t = b.text_field(id: 'firstname') // using the id of the textbox to locate the textbox
t.exists?
t.set 'Riya Kapoor'
b.screenshot.save 'textboxbefore.png'
t.value
t.fire_event('onchange')
b.screenshot.save 'textboxafter.png'
हमारे द्वारा वॉटिर का उपयोग करते हुए जो स्क्रीनशॉट लिए गए हैं, वे यहां दिखाए गए हैं -
textboxbefore.png
textboxafter.png
वॉटिर में पेज ऑब्जेक्ट हमें कक्षाओं के रूप में कोड का पुन: उपयोग करने में मदद करता है। पेज ऑब्जेक्ट सुविधा का उपयोग करके, हम किसी भी कोड को डुप्लिकेट किए बिना अपने ऐप को स्वचालित कर सकते हैं और कोड को प्रबंधनीय भी बना सकते हैं।
परीक्षण करते समय, हम उस प्रत्येक पृष्ठ के लिए पृष्ठ ऑब्जेक्ट बना सकते हैं, जिसका हम परीक्षण करने जा रहे हैं। फिर, हम पेज ऑब्जेक्ट का उपयोग करके विधियों और गुणों तक पहुंचने जा रहे हैं।
पृष्ठ ऑब्जेक्ट का उपयोग करने के पीछे के कारण -
यदि परिवर्तन में किसी भी तरह का बदलाव किया जाता है, तो कोड को फिर से लिखना आवश्यक नहीं है।
कोड अतिरेक से बचने के लिए।
वशीर में पेज-ऑब्जेक्ट का उपयोग करने के लिए हम RSpec का उपयोग करने जा रहे हैं। यदि आप RSpec से परिचित नहीं हैं, तो समझें कि यहाँ RSPec के लिए एक पूर्ण ट्यूटोरियल उपलब्ध है ।
जिस पृष्ठ पर हम परीक्षण करने जा रहे हैं, वह यहाँ दिया गया है -
textbox.html
<html>
<head>
<title>Testing UI using Watir</title>
</head>
<body>
<script type = "text/javascript">
function wsentered() {
console.log("inside wsentered");
var firstname = document.getElementById("firstname");
if (firstname.value != "") {
document.getElementById("displayfirstname").innerHTML =
"The name entered is : " + firstname.value;
document.getElementById("displayfirstname").style.display = "";
}
}
</script>
<div id = "divfirstname">
Enter First Name :
<input type = "text" id = "firstname" name = "firstname" onchange = "wsentered()" />
</div>
<br/>
<br/>
<div style = "display:none;" id = "displayfirstname"></div>
</body>
</html>
उत्पादन
अब हम उपरोक्त पेज के लिए पेज ऑब्जेक्ट बनाएंगे जैसा कि नीचे दिखाया गया है -
pageobjecttest.rb
class InitializeBrowser
def initialize(browser)
@browser = browser
end
end
class TestPage lt; InitializeBrowser
def textbox
@textbox = TestTextbox.new(@browser)
end
def close
@browser.screenshot.save 'usingpageobject.png'
@browser.close
end
end # TestPage
class TestTextbox < InitializeBrowser
URL = "http://localhost/uitesting/textbox.html"
def open
@browser.goto URL
self
end
def enterdata_as(name)
name_field.set name
name_field.fire_event('onchange')
end
private
def name_field
@browser.text_field(:id > "firstname")
end
end # TestTextbox
तीन वर्गों को परिभाषित किया गया है - आरोग्यसेब्रोसर, टेस्टपेज और टेस्टटेक्स्टबॉक्स -
InitializeBrowser - यह खोले गए ब्राउज़र को इनिशियलाइज़ करेगा और ब्राउज़र ऑब्जेक्ट को TestPage और TestTextbox कक्षाओं के साथ साझा करेगा।
TestPage - इस क्लास में TestTextbox का ऑब्जेक्ट रेफरेंस होगा और इसमें स्क्रीनशॉट कैप्चर करने और ब्राउजर को बंद करने की विधि होगी।
TestTextbox - इस क्लास में पेज url खोलने, टेक्स्टफील्ड को रेफरेंस देने, डेटा सेट करने और ऑनकॉन्ग इवेंट को सेट करने के तरीके होंगे।
एक बार जब आप ऊपर दिखाए गए कोड को निष्पादित करते हैं, तो आप नीचे दिखाए अनुसार आउटपुट देख सकते हैं -
Watir Page प्रदर्शन सुविधा आपको प्रतिक्रिया समय मैट्रिक्स को ट्रैक करने की अनुमति देती है और यह क्रोम, फ़ायरफ़ॉक्स, IE9 और इसके बाद के संस्करण में ठीक काम करता है। सफ़ारी ब्राउज़र का अभी समर्थन नहीं है।
आइए हम इस सुविधा का उपयोग करने के बारे में अधिक जानकारी लेते हैं। इसका उपयोग करने के लिए, हमें रत्न का उपयोग करके वियर-प्रदर्शन स्थापित करना होगा जैसा कि नीचे दिखाया गया है -
आदेश
gem install watir-performance
हम वॉटरियर-प्रदर्शन स्थापित करने के साथ किया जाता है। समर्थित मेट्रिक्स हैं -
- summary
- navigation
- memory
- Timing
वतिर-प्रदर्शन का उपयोग कर एक काम करने वाले उदाहरण पर चर्चा की गई है। यहां, हम साइट के लिए प्रतिक्रिया समय की जांच करेंगे - www.tutorialspoint.com जैसा कि नीचे दिखाया गया है -
require 'watir'
require 'watir-performance'
10.times do
b = Watir::Browser.new :chrome
b.goto 'https://www.tutorialspoint.com'
load_secs = b.performance.summary[:response_time] / 1000
puts "Load Time: #{load_secs} seconds."
b.close
end
उत्पादन
Load Time: 7 seconds.
Load Time: 7 seconds.
Load Time: 5 seconds.
Load Time: 5 seconds.
Load Time: 6 seconds.
Load Time: 5 seconds.
Load Time: 5 seconds.
Load Time: 13 seconds.
Load Time: 12 seconds.
Load Time: 5 seconds.
प्रदर्शन का उपयोग करना
require 'watir'
require 'watir-performance'
b = Watir::Browser.new :chrome
b.goto 'https://www.tutorialspoint.com'
load_secs = b.performance.timing[:response_end] - b.performance.timing[:response_start]
puts "Time taken to respond is #{load_secs} seconds."
b.close
उत्पादन
Time taken to respond is 41 seconds.
प्रदर्शन का उपयोग करना
require 'watir'
require 'watir-performance'
b = Watir::Browser.new :chrome
b.goto 'https://www.tutorialspoint.com'
perf_nav = b.performance.navigation
puts "#{perf_nav}"
b.close
उत्पादन
{:type_back_forward=>2, :type_navigate=>0, :type_reload=>1,
:type_reserved=>255, :redirect_count=>0, :to_json=>{}, :type=>0}
प्रदर्शन का उपयोग कर
require 'watir'
require 'watir-performance'
b = Watir::Browser.new :chrome
b.goto 'https://www.tutorialspoint.com'
memory_used = b.performance.memory
puts "#{memory_used}"
b.close
उत्पादन
{:js_heap_size_limit=>2, :type_navigate=>0, :type_reload=>1, :ty2136997888,
:total_js_heap_size=>2, :type_navigate=>0, :type_reload=>1, :ty12990756,
:used_js_heap_size=>2, :type_navigate=>0, :type_reload=>1, :ty7127092}
इस अध्याय में, हम सीखेंगे कि वाटर के साथ कुकीज़ का उपयोग कैसे करें।
एक सरल उदाहरण जो दिए गए URL के लिए कुकीज़ लाएगा, यहां चर्चा की गई है।
कुकीज़ लाने के लिए सिंटैक्स
browser.cookies.to_a
उदाहरण
require 'watir'
b = Watir::Browser.new :chrome
b.goto 'https://www.tutorialspoint.com'
puts b.cookies.to_a
उत्पादन
{:name=>"_gat_gtag_UA_232293_6", :value=>"1", :path=>"/",
:domain=>".tutorialspoint.com", :expires=>2019-05-03 08:33:58 +0000,
:secure=>false}
{:name=>"_gid", :value=> "GA1.2.282573155.1556872379", :path=>"/",
:domain=>".tutorialspoint.com", :expires=>2019-05-04 08:32:57 +0000,
:secure=>false}
{:name=>"_ga", :value=>"GA1.2.2087825339.1556872379", :path=>"/",
:domain=>".tutorialspoint.com", :expires=>
2021-05-02 08:32:57 +0000, :secure=>false}
अब नीचे दिखाए अनुसार कुकीज़ डालते हैं -
कुकीज़ जोड़ने के लिए सिंटैक्स
browser.cookies.add 'cookiename', 'cookievalue', path: '/', expires:
(Time.now + 10000), secure: true
उदाहरण
require 'watir'
b = Watir::Browser.new :chrome
b.goto 'https://www.tutorialspoint.com'
puts b.cookies.to_a
b.cookies.add 'cookie1', 'testing_cookie', path: '/', expires:
(Time.now + 10000), secure: true
puts b.cookies.to_a
कुकी जोड़ने से पहले आउटपुट
{:name=>"_gat_gtag_UA_232293_6", :value=>"1", :path=>"/",
:domain=>".tutorialspoint.com", :expires=>2019-05-03 08:44:23 +0000,
:secure=>false}
{:name=>"_gid", :value=>"GA1.2.1541488984.1556873004",
:path=>"/", :domain=>".tutorialspoint.com",
:expires=>2019-05-04 08:43:24 +0000, :secure=>false}
{:name=>"_ga", :value=>"GA1.2.1236163943.1556873004",
:path=>"/", :domain=>".tutorialspoint.com",
:expires=>2021-05-02 08:43:24 +0000, :secure=>false}
कुकी जोड़ने के बाद आउटपुट
{:name=>"_gat_gtag_UA_232293_6", :value=>"1", :path=>"/",
:domain=>".tutorialspoint.com", :expires=>2019-05-03 08:44:23 +0000,
:secure=>false}
{:name=>"_gid", :value=>"GA1.2.1541488984.1556873004",
:path=>"/", :domain=>".tutorialspoint.com",
:expires=>2019-05-04 08:43:24 +0000, :secure=>false}
{:name=>"_ga", :value=>"GA1.2.1236163943.1556873004",
:path=>"/", :domain=>".tutorialspoint.com",
:expires=>2021-05-02 08:43:24 +0000, :secure=>false}
{:name=>"cookie1", :value=>"testing_cookie", :path=>"/",
:domain=>"www.tutorialspoint.com", :expires=>2039-04-28 08:43:35 +0000,
:secure=>true}
ध्यान दें कि अंतिम वह है जिसे हमने वाइट का उपयोग करके जोड़ा था।
कुकी साफ़ करें
वाक्य - विन्यास
browser.cookies.clear
उदाहरण
require 'watir'
b = Watir::Browser.new :chrome
b.goto 'https://www.tutorialspoint.com'
puts b.cookies.to_a
b.cookies.clear
puts b.cookies.to_a
उत्पादन
{:name=>"_gat_gtag_UA_232293_6", :value=>"1", :path=>"/",
:domain=>".tutorialspoint.com", :expires=>2019-05-03 08:48:29 +0000,
:secure=>false}
{:name=>"_gid", :value=>"GA1.2.1264249563.1556873251",
:path=>"/", :domain=>".tutorialspoint.com",
:expires=>2019-05-04 08:47:30 +0000, :secure=>false}
{:name=>"_ga", :value=>"GA1.2.1001488637.1556873251",
:path=>"/", :domain=>".tutorialspoint.com",
:expires=>2021-05-02 08:47:30 +0000, :secure=>false
Empty response ie a blank line will get printed after cookie.clear is called.
किसी विशेष कुकी को हटाएं
वाक्य - विन्यास
browser.cookies.delete 'nameofthecookie'
उदाहरण
require 'watir'
b = Watir::Browser.new :chrome
b.goto 'https://www.tutorialspoint.com'
puts b.cookies.to_a
puts b.cookies.delete "_ga"
puts b.cookies.to_a
उत्पादन
All cookies:
{:name=>"_gat_gtag_UA_232293_6", :value=>"1", :path=>"/",
:domain=>".tutorialspoint.com", :expires=>2019-05-03 08:52:38 +0000,
:secure=>false}
{:name=>"_gid", :value=>"GA1.2.1385195240.1556873499",
:path=>"/", :domain=>".tutorialspoint.com",
:expires=>2019-05-04 08:51:37 +0000, :secure=>false}
{:name=>"_ga", :value=>"GA1.2.1383421835.1556873499",
:path=>"/", :domain=>".tutorialspoint.com",
:expires=>2021-05-02 08:51:37 +0000, :secure=>false}
After delete cookie with name _ga
{:name=>"_gat_gtag_UA_232293_6",
:value=>"1", :path=>"/", :domain=>".tutorialspoint.com",
:expires=>2019-05-03 08:52:38 +0000, :secure=>false}
{:name=>"_gid", :value=>"GA1.2.1385195240.1556873499",
:path=>"/", :domain=>".tutorialspoint.com",
:expires=>2019-05-04 08:51:37 +0000, :secure=>false}
Watir प्रॉक्सी ऑब्जेक्ट की मदद से प्रॉक्सी का उपयोग करने की अनुमति देता है जिसे ब्राउज़र के साथ उपयोग करने की आवश्यकता होती है।
वाक्य - विन्यास
proxy = {
http: '127.0.0.1:8080',
ssl: '127.0.0.1:8080'
}
b = Watir::Browser.new :chrome, proxy: proxy
क्रोम ब्राउज़र के साथ प्रॉक्सी का उपयोग कैसे करें पर एक उदाहरण नीचे दिखाया गया है -
उदाहरण
require "watir"
proxy = {
http: '127.0.0.1:8080',
ssl: '127.0.0.1:8080'
}
b = Watir::Browser.new :chrome, proxy: proxy
b.goto 'google.com'
b.screenshot.save 'proxy.png'
हमने नीचे दिखाए अनुसार प्रॉक्सी ऑब्जेक्ट का उपयोग किया है -
proxy = {
http: '127.0.0.1:8080',
ssl: '127.0.0.1:8080'
}
प्रॉक्सी पते का विवरण http और ssl दोनों के लिए उपयोग किया जाना है। हम क्रोम ब्राउज़र के साथ प्रॉक्सी का उपयोग कर सकते हैं जैसा कि नीचे दिखाया गया है -
b = Watir::Browser.new :chrome, proxy: proxy
आउटपुटxy.png नीचे दिखाया गया है -
फ़ायरफ़ॉक्स ब्राउज़र के साथ प्रॉक्सी का उपयोग कैसे करें पर एक उदाहरण नीचे चर्चा की गई है -
उदाहरण
require "watir"
proxy = {
http: '127.0.0.1:8080',
ssl: '127.0.0.1:8080'
}
b = Watir::Browser.new :firefox, proxy: proxy
b.goto 'google.com'
b.screenshot.save 'proxyfirefox.png'
आप नीचे दिखाए अनुसार प्रॉक्सी विवरण जोड़ सकते हैं -
proxy = {
http: '127.0.0.1:8080',
ssl: '127.0.0.1:8080'
}
b = Watir::Browser.new :firefox, proxy: proxy
यहाँ पर दिखाया गया है।
इस अध्याय में हम समझेंगे कि वॉटिर का उपयोग करके अलर्ट कैसे संभालें।
वाक्य - विन्यास
browser.alert.exists?
browser.alert.ok
browser.alert.close
Testpage
<html>
<head>
<title>Testing Alerts Using Watir</title>
</head>
<body>
<script type = "text/javascript">
function wsformsubmitted() {
alert("Button is Clicked !");
}
</script>
<button id = "btnsubmit" onclick = "wsformsubmitted();">Submit</button>
</body>
</html>
वातिर कोड
require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/testalert.html')
b.button(id: 'btnsubmit').click
b.alert.ok
b.screenshot.save 'alerttest.png'
आउटपुट अलर्टस्ट.पिंग को यहाँ दिखाया गया है -
हमारे पास यूआई या हमारी वेबसाइट में बटन या लिंक हैं जो एक पीडीएफ, या एक डॉक डाउनलोड करते हैं। हम ब्राउज़र के लिए कुछ वरीयताएँ देकर वॉटिर के साथ उपयोग करने के लिए परीक्षण कर सकते हैं।
डाउनलोड करने के लिए वाक्यविन्यास -
prefs = {
'download' => {
'default_directory' => "C:/download",
'prompt_for_download' => false,
}
}
b = Watir::Browser.new :chrome, options: {prefs: prefs}
प्रीफ़्स ने डाउनलोड किया है जिसमें हमें वह रास्ता देना होगा जहाँ हम चाहते हैं कि फ़ाइल डाउनलोड होने के बाद संग्रहित की जाए और वही ऊपर दिए गए सिंटैक्स में दिखाए गए विकल्पों का उपयोग करके ब्राउज़र को दी जाए।
एक कामकाजी उदाहरण यहां दिखाया गया है। यहां, हमने एक बटन के साथ टेस्ट पेज बनाया है, जिस पर क्लिक करने पर नीचे दिखाए गए अनुसार file.txt नामक फाइल डाउनलोड हो जाएगी -
<html>
<head>
<title>Testing UI using Watir</title>
</head>
<body>
<br/>
<br/>
<button id = "btnsubmit">
<a href = "file.txt" download>Click to Download!</a>
</button>
<br/>
</body>
</html>
file.txt
This is for testing watir download
उत्पादन
जब आप डाउनलोड बटन पर क्लिक करते हैं, तो फ़ाइल डाउनलोड की जाती है।
अब आइए हम वतिर का उपयोग करके उसी का परीक्षण करते हैं -
require 'watir'
prefs = {
'download' => {
'default_directory' => "C:/download",
'prompt_for_download' => false,
}
}
b = Watir::Browser.new :chrome, options: {prefs: prefs}
b.goto('http://localhost/uitesting/filedownload.html')
b.button(id: 'btnsubmit').click
b.screenshot.save 'testdownload.png'
डाउनलोड की गई फ़ाइल को संग्रहीत करने के लिए हमने जो पथ दिया है वह "C: / डाउनलोड" है। जब हम उपरोक्त कोड निष्पादित करते हैं, तो हमारे पास डाउनलोड पथ में फ़ाइल डाउनलोड होगा जैसा कि नीचे दिखाया गया है -
आउटपुट testdownload.png यहाँ दिखाया गया है -
आपके सामने ऐसे मामले आएंगे, जहां हमें पॉपअप विंडो का उपयोग करना होगा या नई ब्राउज़र विंडो खोलना होगा। इस अध्याय में, हम चर्चा करेंगे कि वटिर का उपयोग करके ऐसे मामलों का परीक्षण कैसे किया जाए।
वाक्य - विन्यास
browser.window
एक कामकाजी उदाहरण जो हम परीक्षण करने जा रहे हैं वह यहां दिया गया है -
<html>
<head>
<title>Testing UI using Watir</title>
</head>
<body>
<script type = "text/javascript">
function wsclick() {
var myWindow = window.open(
"https://www.google.com/", "mywindow", "width = 1000,height = 500");
}
</script>
<form name = "myform" method = "POST">
<div>
<br>
<input type = "button" id = "btnsubmit" name = "btnsubmit" value = "submit" onclick = "wsclick()"/>
<br>
</div>
</form>
<br/>
</body>
</html>
उत्पादन
बटन ओपन विंडो के ऑन-क्लिक पर, पॉपअप विंडो खुल जाती है। यहाँ, हमने जो यूआरएल दिया है वह www.google.com है । अब आइए हम वाटरर /
उदाहरण
require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/windowpopup.html')
b.button(id: 'btnsubmit').click
b.window(title: 'Google').use do
b.screenshot.save 'popupwindow.png'
t = b.text_field(class: 'gLFyf')
t.set 'Watir'
b.screenshot.save 'popupwindowbefore.png'
b.button(name: 'btnK').click
b.screenshot.save 'popupwindowafter.png'
end
हमने जो स्क्रीनशॉट लिए हैं, वे नीचे दिए गए हैं -