कॉम्पोनेन्ट टेस्टिंग
WebdriverIOs Browser Runner के साथ आप WebdriverIO और WebDriver प्रोटोकॉल का उपयोग करते हुए एक वास्तविक डेस्क टॉप या मोबाइल ब्राउज़र के भीतर परीक्षण चला सकते हैं ताकि पेज पर जो प्रस्तुत किया जाता है उसे स्वचालित और इंटरैक्ट किया जा सके। इस दृष्टिकोण के अन्य परीक्षण ढांचे की तुलना में कई फायदे हैं जो केवल JSDOMके खिलाफ परीक्षण की अनुमति देते हैं।
यह कैसे काम करता है?
ब्राउज़र रनर एक परीक्षण पेज प्रस्तुत करने के लिए Vite का उपयोग करता है और ब्राउज़र में आपके परीक्षण चलाने के लिए एक परीक्षण फ्रेमवर्क आरंभ करता है। वर्तमान में यह केवल मोचा का समर्थन करता है लेकिन जैस्मीन और कुकुम्बर रोडमैप पर है. यह उन परियोजनाओं के लिए भी किसी भी प्रकार के कॉम् पोनेन्ट का परीक्षण करने की अनुमति देता है जो Vite का उपयोग नहीं करते हैं।
Vite सर्वर WebdriverIO टेस्टरनर द्वारा शुरू किया गया है और कॉन्फ़िगर किया गया है ताकि आप सभी रिपोर्टर और सेवाओं का उपयोग कर सकें जैसा कि आप सामान्य e2e परीक्षणों के लिए करते थे। Furthermore it initializes a browser
instance that allows you to access a subset of the WebdriverIO API to interact with the any elements on the page. E2e परीक्षणों के समान आप वैश्विक दायरे से जुड़े browser
वेरिएबल के माध्यम से या @wdio/globals
से आयात करके इस उदाहरण तक पहुंच सकते हैं, यह इस बात पर निर्भर करता है कि njectGlobals
कैसे सेट किया गया है।
WebdriverIO has built-in support for the following frameworks:
- Nuxt: WebdriverIO's testrunner detects a Nuxt application and automatically sets up your project composables and helps mock out the Nuxt backend, read more in the Nuxt docs
- TailwindCSS: WebdriverIO's testrunner detects if you are using TailwindCSS and loads the environment properly into the test page
सेटअप
ब्राउज़र में यूनिट या घटक परीक्षण के लिए WebdriverIO सेट-अप करने के लिए, एक नया WebdriverIO प्रोजेक्ट आरंभ करें:
npm init wdio@latest ./
# or
yarn create wdio ./
एक बार कॉन्फ़िगरेशन विज़ार्ड शुरू होने के बाद, यूनिट और कॉम्पोनेन्ट प रीक्षण चलाने के लिए browser
चुनें और यदि वांछित हो तो प्रीसेट में से एक चुनें अन्यथा "अन्य" के साथ जाएं यदि आप केवल मूल यूनिट परीक्षण चलाना चाहते हैं। यदि आप अपने प्रोजेक्ट में पहले से ही Vite का उपयोग करते हैं, तो आप एक कस्टम Vite कॉन्फ़िगरेशन भी कॉन्फ़िगर कर सकते हैं। अधिक जानकारी के लिए सभी रनर विकल्पदेखें।
नोट: WebdriverIO डिफ़ॉल्ट रूप से CI में ब्राउज़र परीक्षण चलाएगा, उदाहरण के लिए CI
पर्यावरण चर '1'
या 'true'
पर सेट है। आप रनर के लिए headless
विकल्प का उपयोग करके मैन्युअल रूप से इस व्यवहार को कॉन्फ़िगर कर सकते हैं।
इस प्रक्रिया के अंत में आप को एक wdio.conf.js
मिलना चाहिए जिसमें विभिन्न WebdriverIO कॉन्फ़िगरेशन शामिल हैं, जिसमें runner
प्रॉपर्टी शामिल है, उदाहरण के लिए:
loading...
विभिन्न क्षमताओं को परिभाषित करके आप अलग-अलग ब्राउज़र में अपने परीक्षण चला सकते हैं, यदि वांछित हो तो समानांतर में।
If you are still unsure how everything works, watch the following tutorial on how to get started with Component Testing in WebdriverIO:
हर्नेस परिक्षण
यह पूरी तरह आप पर निर्भर है कि आप अपने परीक्षणों में क्या चलाना चाहते हैं और आप कॉम्पोनेन्ट को कैसे प्रस्तुत करना पसंद करते हैं। हालाँकि हम टेस्टिंग लाइब्रेरी को यूटिलिटी फ्रेमवर्क के रूप में उपयोग करने की सलाह देते हैं क्योंकि यह विभिन्न घटक फ्रेमवर्क के लिए प्लगइन्स प्रदान करता है, जैसे कि React, Preact, Svelte और Vue। परीक्षण प ेज में कॉम्पोनेन्ट को प्रस्तुत करने के लिए यह बहुत उपयोगी है और यह प्रत्येक परीक्षण के बाद स्वचालित रूप से इन कॉम्पोनेन्ट को क्लीन करता है।
आप अपनी इच्छानुसार WebdriverIO कमांड के साथ टेस्टिंग लाइब्रेरी प्रिमिटिव को मिला सकते हैं, जैसे:
loading...
नोट: टेस्टिंग लाइब्रेरी से रेंडर विधियों का उपयोग करने से परीक्षणों के बीच बनाए गए कॉम्पोनेन्ट को हटाने में मदद मिलती है। यदि आप परीक्षण लाइब्रेरी का उपयोग नहीं करते हैं तो अपने परीक्षण कॉम्पोनेन्ट को एक ऐसे कंटेनर से जोड़ना सुनिश्चित करें जो परीक्षणों के क्लीन हो जाता है।
सेटअप स्क्रिप्ट
आप Node.js या ब्राउज़र में मनमानी स्क्रिप्ट चलाकर अपने परीक्षण सेट कर सकते हैं, उदाहरण के लिए शैलियों को इंजेक्ट करना, ब्राउज़र API का मज़ाक उड़ाना या किसी तृतीय पक्ष सेवा से कनेक्ट करना। WebdriverIO हुक का उपयोग Node.js में कोड चलाने के लिए किया जा सकता है जबकि mochaOpts.require
आपको परीक्षण लोड होने से पहले ब्राउज़र में स्क्रिप्ट आयात करने की अनुमति देता है, जैसे:
एक्सपोर्ट const config = {
// ...
मोचाऑप्ट्स: {
यूआई: 'टीडीडी',
// ब्राउज़र में चलने के लिए एक सेटअप स्क्रिप्ट प्रदान करें
आवश्यकता: './__fixtures__/setup.js'
},
पहले: () => {
// Node.js में परीक्षण वातावरण सेट करें
}
// ...
}
उदाहरण के लिए, यदि आप निम्न सेट-अप स्क्रिप्ट के साथ अपने परीक्षण में सभी fetch()
कॉलों का मजाक उड़ाना पसंद करते हैं:
'@wdio/browser-runner' से { fn } आयात करें
// रन कोड सभी परीक्षण लोड होने से पहले
विंडो.फ़ेच = fn ()
निर्यात const mochaGlobalSetup = () => {
// रन कोड परीक्षण फ़ाइल लोड होने के बाद
}
Export const mochaGlobalTeardown = () => {
// युक्ति फ़ाइल निष्पादित होने के बाद रन कोड
}
अब अपने परीक्षणों में आप सभी ब्राउज़र अनुरोधों के लिए कस्टम प्रतिक्रिया मान प्रदान कर सकते हैं। मोचा डॉक्समें वैश्विक फिक्स्चर पर अधिक पढ़ें।
परीक्षण और एप्लिकेशन फ़ाइलें देखें
आप अपने ब्राउज़र परीक्षणों को डीबग करने के कई तरीके हैं। WebdriverIO टेस्टरनर को --watch
फ़्लैग से शुरू करना सबसे आसान है, जैसे:
$ npx wdio run ./wdio.conf.js --watch
यह शुरू में सभी परीक्षणों के माध्यम से चलेगा और सभी के चलने के बाद रुक जाएगा। फिर आप अलग-अलग फाइलों में बदलाव कर सकते हैं, जो फिर अलग-अलग फिर से चलाए जाएंगे। यदि आप अपनी एप्लिकेशन फ़ाइलों की ओर इशारा करते हुए filesToWatch
सेट करते हैं, तो आपके ऐप में बदलाव किए जाने पर यह सभी परीक्षणों को फिर से चलाएगा।