पायथन वेब स्क्रैपिंग - स्क्रैपर के साथ परीक्षण
यह अध्याय बताता है कि पायथन में वेब स्क्रेपर्स का उपयोग करके परीक्षण कैसे किया जाता है।
परिचय
बड़ी वेब परियोजनाओं में, वेबसाइट के बैकएंड का स्वचालित परीक्षण नियमित रूप से किया जाता है, लेकिन फ्रंटेंड परीक्षण को अक्सर छोड़ दिया जाता है। इसके पीछे मुख्य कारण यह है कि वेबसाइटों की प्रोग्रामिंग विभिन्न मार्कअप और प्रोग्रामिंग भाषाओं के जाल की तरह है। हम एक भाषा के लिए यूनिट टेस्ट लिख सकते हैं लेकिन यह दूसरी भाषा में बातचीत हो रही है तो यह चुनौतीपूर्ण हो जाता है। इसीलिए हमारे पास यह सुनिश्चित करने के लिए हमारे पास परीक्षण का सूट होना चाहिए कि हमारी अपेक्षा के अनुसार हमारा कोड प्रदर्शन कर रहा है।
पायथन का उपयोग करके परीक्षण
जब हम परीक्षण के बारे में बात कर रहे हैं, तो इसका मतलब इकाई परीक्षण है। अजगर के साथ परीक्षण में गहरी गोता लगाने से पहले, हमें इकाई परीक्षण के बारे में पता होना चाहिए। इकाई परीक्षण की कुछ विशेषताएं निम्नलिखित हैं -
घटक की कार्यक्षमता का कम से कम एक पहलू प्रत्येक इकाई परीक्षण में परीक्षण किया जाएगा।
प्रत्येक इकाई परीक्षण स्वतंत्र है और स्वतंत्र रूप से भी चल सकता है।
यूनिट टेस्ट किसी अन्य परीक्षण की सफलता या विफलता में हस्तक्षेप नहीं करता है।
इकाई परीक्षण किसी भी क्रम में चल सकते हैं और इसमें कम से कम एक अभिकथन होना चाहिए।
यूनीटेस्ट - पायथन मॉड्यूल
यूनिट परीक्षण के लिए यूनीटेस्ट नामक पायथन मॉड्यूल सभी मानक पायथन इंस्टॉलेशन के साथ आता है। हमें बस इसे आयात करने की आवश्यकता है और बाकी का काम unittest.TestCase क्लास का कार्य है जो निम्नलिखित कार्य करेगा -
सेटअप और टियरडाउन फ़ंक्शंस unittest.TestCase क्लास द्वारा दिए गए हैं। ये कार्य प्रत्येक इकाई परीक्षण से पहले और बाद में चल सकते हैं।
यह परीक्षणों को पारित करने या विफल होने की अनुमति देने के लिए मुखर वक्तव्य भी प्रदान करता है।
यह सभी कार्यों को चलाता है जो कि test_ के रूप में Unit test से शुरू होते हैं।
उदाहरण
इस उदाहरण में हम वेब स्क्रैपिंग को संयोजित करने जा रहे हैं unittest। हम स्ट्रिंग 'पायथन' की खोज के लिए विकिपीडिया पृष्ठ का परीक्षण करेंगे। यह मूल रूप से दो परीक्षण करेगा, पहले मौसम का शीर्षक पृष्ठ खोज स्ट्रिंग के रूप में एक ही है अर्थात 'पैटन' या नहीं और दूसरा परीक्षण यह सुनिश्चित करता है कि पृष्ठ में सामग्री div है।
सबसे पहले, हम आवश्यक पायथन मॉड्यूल आयात करेंगे। हम वेब स्क्रैपिंग के लिए और परीक्षण के लिए एकतरफा होने के लिए ब्यूटीफुल का उपयोग कर रहे हैं।
from urllib.request import urlopen
from bs4 import BeautifulSoup
import unittest
अब हमें एक वर्ग को परिभाषित करने की आवश्यकता है जो कि unittest.TestCase का विस्तार करेगा। सभी परीक्षणों के बीच वैश्विक ऑब्जेक्ट bs साझा किया जाएगा। एक विशिष्ट निर्दिष्ट फ़ंक्शन सेटअपक्लास इसे पूरा करेगा। यहां हम दो कार्यों को परिभाषित करेंगे, एक शीर्षक पृष्ठ के परीक्षण के लिए और दूसरा पृष्ठ सामग्री के परीक्षण के लिए।
class Test(unittest.TestCase):
bs = None
def setUpClass():
url = '<a target="_blank" rel="nofollow" href="https://en.wikipedia.org/wiki/Python">https://en.wikipedia.org/wiki/Python'</a>
Test.bs = BeautifulSoup(urlopen(url), 'html.parser')
def test_titleText(self):
pageTitle = Test.bs.find('h1').get_text()
self.assertEqual('Python', pageTitle);
def test_contentExists(self):
content = Test.bs.find('div',{'id':'mw-content-text'})
self.assertIsNotNone(content)
if __name__ == '__main__':
unittest.main()
उपरोक्त स्क्रिप्ट को चलाने के बाद हम निम्नलिखित आउटपुट प्राप्त करेंगे -
----------------------------------------------------------------------
Ran 2 tests in 2.773s
OK
An exception has occurred, use %tb to see the full traceback.
SystemExit: False
D:\ProgramData\lib\site-packages\IPython\core\interactiveshell.py:2870:
UserWarning: To exit: use 'exit', 'quit', or Ctrl-D.
warn("To exit: use 'exit', 'quit', or Ctrl-D.", stacklevel=1)
सेलेनियम के साथ परीक्षण
आइए चर्चा करें कि परीक्षण के लिए पायथन सेलेनियम का उपयोग कैसे करें। इसे सेलेनियम परीक्षण भी कहा जाता है। दोनों पायथनunittest तथा Seleniumबहुत आम नहीं है। हम जानते हैं कि सेलेनियम अपने ब्राउज़र के डिज़ाइन में भिन्नता के बावजूद, मानक पायथन को विभिन्न ब्राउज़रों को भेजता है। याद करें कि हमने पहले ही सेलेनियम के साथ काम किया था और पिछले अध्यायों में काम किया था। यहां हम सेलेनियम में परीक्षण स्क्रिप्ट बनाएंगे और इसका उपयोग स्वचालन के लिए करेंगे।
उदाहरण
अगले पायथन स्क्रिप्ट की मदद से, हम फेसबुक लॉगिन पेज के स्वचालन के लिए टेस्ट स्क्रिप्ट बना रहे हैं। आप अपनी पसंद के अन्य रूपों और लॉगिन को स्वचालित करने के लिए उदाहरण को संशोधित कर सकते हैं, हालांकि अवधारणा समान होगी।
वेब ब्राउज़र से कनेक्ट करने के लिए सबसे पहले, हम सेलेनियम मॉड्यूल से वेबड्राइवर आयात करेंगे -
from selenium import webdriver
अब, हमें सेलेनियम मॉड्यूल से कीज़ को आयात करने की आवश्यकता है।
from selenium.webdriver.common.keys import Keys
आगे हमें अपने फेसबुक अकाउंट में लॉगिन के लिए यूजरनेम और पासवर्ड देना होगा
user = "[email protected]"
pwd = ""
इसके बाद, Chrome के लिए वेब ड्राइवर को पथ प्रदान करें।
path = r'C:\\Users\\gaurav\\Desktop\\Chromedriver'
driver = webdriver.Chrome(executable_path=path)
driver.get("http://www.facebook.com")
अब हम मुखर खोजशब्द का उपयोग करके शर्तों को सत्यापित करेंगे।
assert "Facebook" in driver.title
निम्नलिखित कोड की मदद से हम ईमेल सेक्शन में मान भेज रहे हैं। यहां हम इसे इसकी आईडी से खोज रहे हैं लेकिन हम इसे नाम से भी खोज सकते हैंdriver.find_element_by_name("email")।
element = driver.find_element_by_id("email")
element.send_keys(user)
निम्नलिखित कोड की मदद से हम पासवर्ड सेक्शन को मान भेज रहे हैं। यहां हम इसे इसकी आईडी से खोज रहे हैं लेकिन हम इसे नाम से भी खोज सकते हैंdriver.find_element_by_name("pass")।
element = driver.find_element_by_id("pass")
element.send_keys(pwd)
ईमेल और पासवर्ड फ़ील्ड में मान डालने के बाद कोड की अगली पंक्ति का उपयोग एंटर / लॉगिन को दबाने के लिए किया जाता है।
element.send_keys(Keys.RETURN)
अब हम ब्राउज़र को बंद कर देंगे।
driver.close()
उपरोक्त स्क्रिप्ट चलाने के बाद, Chrome वेब ब्राउज़र खोला जाएगा और आप देख सकते हैं कि ईमेल और पासवर्ड डाला जा रहा है और लॉगिन बटन पर क्लिक किया जा रहा है।
तुलना: एकतरफा या सेलेनियम
यूनीटेस्ट और सेलेनियम की तुलना मुश्किल है क्योंकि यदि आप बड़े परीक्षण सूट के साथ काम करना चाहते हैं, तो एकजुट होने की क्रमिक कठोरता की आवश्यकता होती है। दूसरी ओर, यदि आप वेबसाइट के लचीलेपन का परीक्षण करने जा रहे हैं तो सेलेनियम टेस्ट हमारी पहली पसंद होगी। लेकिन क्या होगा अगर हम दोनों को जोड़ सकते हैं। हम पाइथन में सेलेनियम को एकतरफा आयात कर सकते हैं और दोनों का सर्वश्रेष्ठ प्राप्त कर सकते हैं। सेलेनियम का उपयोग किसी वेबसाइट के बारे में जानकारी प्राप्त करने के लिए किया जा सकता है और एकटा मूल्यांकन कर सकता है कि वह जानकारी परीक्षण पास करने के मानदंडों को पूरा करती है या नहीं।
उदाहरण के लिए, हम ऊपर दिए गए पायथन लिपि को फिर से लिख रहे हैं।
import unittest
from selenium import webdriver
class InputFormsCheck(unittest.TestCase):
def setUp(self):
self.driver = webdriver.Chrome(r'C:\Users\gaurav\Desktop\chromedriver')
def test_singleInputField(self):
user = "[email protected]"
pwd = ""
pageUrl = "http://www.facebook.com"
driver=self.driver
driver.maximize_window()
driver.get(pageUrl)
assert "Facebook" in driver.title
elem = driver.find_element_by_id("email")
elem.send_keys(user)
elem = driver.find_element_by_id("pass")
elem.send_keys(pwd)
elem.send_keys(Keys.RETURN)
def tearDown(self):
self.driver.close()
if __name__ == "__main__":
unittest.main()