கூறு சோதனை
WebdriverIOs Browser Runner மூலம் நீங்கள் உண்மையான டெஸ்க்டாப் அல்லது மொபைல் உலாவியில் சோதனைகளை இயக்கலாம். இதற்கு WebdriverIO மற்றும் WebDriver நெறிமுறையைப் பயன்படுத்தி பக்கத்தில் காட்டப்படும் விஷயங்களை தானியங்கி முறையில் இயக்க முடியும். மற்ற சோதனை கட்டமைப்புகளை விட இந்த அணுகுமுறை பல நன்மைகளை கொண்டுள்ளது, இவை JSDOM மட்டுமே சோதிக்க அனுமதிக்கின்றன.
இது எவ்வாறு செயல்படுகிறது?
Browser Runner, Vite ஐப் பயன்படுத்தி ஒரு சோதனைப் பக்கத்தை உருவாக்கி, உலாவியில் உங்கள் சோதனைகளை இயக்க சோதனை கட்டமைப்பை துவக்குகிறது. தற்போது Mocha மட்டுமே ஆதரிக்கப்படுகிறது, ஆனால் Jasmine மற்றும் Cucumber திட்டமிடப்பட்டுள்ளன. இது Vite ஐப் பயன்படுத்தாத திட்டங்களுக்கும் எந்த வகையான கூறுகளையும் சோதிக்க அனுமதிக்கிறது.
Vite சேவையகம் WebdriverIO சோதனை இயக்கியால் தொடங்கப்பட்டு, வழக்கமான e2e சோதனைகளுக்கு நீங்கள் பயன்படுத்திய அனைத்து அறிக்கையாளர்களையும் சேவைகளையும் பயன்படுத்தும் வகையில் கட்டமைக்கப்படுகிறது. மேலும் இது ஒரு browser
உறுப்பை உருவாக்குகிறது, இது பக்கத்தில் உள்ள எந்த கூறுகளுடனும் தொடர்புகொள்ள WebdriverIO API இன் ஒரு துணைக்குழுவை அணுக அனுமதிக்கிறது. e2e சோதனைகளைப் போலவே, நீங்கள் அந்த உறுப்பை உலகளாவிய நோக்கில் இணைக்கப்பட்ட browser
மாறியின் மூலம் அல்லது injectGlobals
எவ்வாறு அமைக்கப்பட்டுள்ளது என்பதைப் பொறுத்து @wdio/globals
இலிருந்து இறக்குமதி செய்வதன் மூலம் அணுகலாம்.
WebdriverIO பின்வரும் கட்டமைப்புகளுக்கு உள்ளமைந்த ஆதரவைக் கொண்டுள்ளது:
- Nuxt: WebdriverIO சோதனை இயக்கி ஒரு Nuxt பயன்பாட்டைக் கண்டறிந்து, உங்கள் திட்ட composables ஐத் தானாகவே அமைத்து, Nuxt பின்னணியை மாதிரியாக்க உதவுகிறது, Nuxt ஆவணங்களில் மேலும் படிக்கவும்
- TailwindCSS: WebdriverIO சோதனை இயக்கி நீங்கள் TailwindCSS ஐப் பயன்படுத்துகிறீர்களா என்பதைக் கண்டறிந்து, சூழலை சோதனைப் பக்கத்தில் சரியாக ஏற்றுகிறது
அமைப்பு
உலாவியில் யூனிட் அல்லது கூறு சோதனைக்காக WebdriverIO ஐ அமைக்க, புதிய WebdriverIO திட்டத்தை இவ்வாறு தொடங்கவும்:
npm init wdio@latest ./
# or
yarn create wdio ./
கட்டமைப்பு வழிகாட்டி தொடங்கியவுடன், யூனிட் மற்றும் கூறு சோதனைகளை இயக்குவதற்கு browser
ஐத் தேர்வுசெய்து, விருப்பமான முன்அமைவுகளைத் தேர்வுசெய்யவும். அல்லது அடிப்படை யூனிட் சோதனைகளை மட்டும ் இயக்க விரும்பினால் "Other" ஐத் தேர்வுசெய்யவும். உங்கள் திட்டத்தில் ஏற்கனவே Vite ஐப் பயன்படுத்தினால், தனிப்பயன் Vite கட்டமைப்பையும் கட்டமைக்கலாம். மேலும் தகவலுக்கு ரன்னர் விருப்பங்கள் அனைத்தையும் பார்க்கவும்.
குறிப்பு: WebdriverIO இயல்பாக CI சூழலில் உலாவி சோதனைகளை headlessly இயக்கும், எ.க. CI
சூழல் மாறி '1'
அல்லது 'true'
என அமைக்கப்பட்டிருந்தால். headless
விருப்பத்தைப் பயன்படுத்தி இந்த நடத்தையை கைமுறையாக கட்டமைக்கலாம்.
இந்த செயல்முறையின் முடிவில் நீங்கள் ஒரு wdio.conf.js
ஐக் காணலாம், இதில் பல்வேறு WebdriverIO கட்டமைப்புகள் உள்ளன, இதில் runner
பண ்பும் அடங்கும், எ.க.:
loading...
வெவ்வேறு திறன்களை வரையறுப்பதன் மூலம், உங்கள் சோதனைகளை வெவ்வேறு உலாவிகளில், விரும்பினால் இணையாக இயக்கலாம்.
எல்லாம் எப்படி வேலை செய்கிறது என்பதில் இன்னும் தெளிவில்லை என்றால், WebdriverIO இல் கூறு சோதனையைத் தொடங்குவதற்கான பின்வரும் பயிற்சிக் காணொளியைப் பார்க்கவும்:
சோதனை ஹார்னெஸ்
உங்கள் சோதனைகளில் என்ன இயக்க வேண்டும் மற்றும் கூறுகளை எவ்வாறு காட்ட விரும்புகிறீர்கள் என்பது முற்றிலும் உங்களைப் பொறுத்தது. இருப்பினும், Testing Library ஐ பயன்பாட்டு கட்டமைப்பாகப் பயன்படுத்த பரிந்துரைக்கிறோம், ஏனெனில் இது React, Preact, Svelte மற்றும் Vue போன்ற பல்வேறு கூறு கட்டமைப்புகளுக்கான செருகுநிரல்களை வழங்குகிறது. இது சோதனைப் பக்கத்தில் கூறுகளைக் காட்டுவதற்கு மிகவும் பயனுள்ளதாக உள்ளது, மேலும் இது ஒவ்வொரு சோதனைக்குப் பிறகும் இந்தக் கூறுகளைத் தானாகவே சுத்தம் செய்கிறது.
நீங்கள் Testing Library அடிப்படைகளை WebdriverIO கட்டளைகளுடன் விரும்பியபடி கலக்கலாம், எ.க.:
loading...
குறிப்பு: Testing Library இலிருந்து ரெண்டர் முறைகளைப் பயன்படுத்துவது சோதனைகளுக்கு இடையில் உருவாக்கப்பட்ட கூறுகளை அகற்ற உதவுகிறது. நீங்கள் Testing Library ஐப் பயன்படுத்தவில்லை என்றால், உங்கள் சோதனைக் கூறுகளை சோதனைகளுக்கு இடையில் சுத்தம் செய்யப்படும் ஒரு கொள்கலனுடன் இணைக்கவும்.
அமைப்பு ஸ்கிரிப்ட்கள்
நீங்கள் Node.js அல்லது உலாவியில் தன்னிச்சையான ஸ்கிரிப்ட்களை இயக்குவதன் மூலம் உங்கள் சோதனைகளை அமைக்கலாம், எ.க. ஸ்டைல்களைச் செருகுதல், உலாவி API களை மாதிரியாக்குதல் அல்லது மூன்றாம் தரப்பு சேவையுடன் இணைத்தல். WebdriverIO hooks Node.js இல் குறியீட்டை இயக்கப் பயன்படுத்தலாம், அதே நேரத்தில் mochaOpts.require
சோதனைகள் ஏற்றப்படுவதற்கு முன் ஸ்கிரிப்ட்களை உலாவிக்கு இறக்குமதி செய்ய அனுமதிக்கிறது, எ.க.:
export const config = {
// ...
mochaOpts: {
ui: 'tdd',
// provide a setup script to run in the browser
require: './__fixtures__/setup.js'
},
before: () => {
// set up test environment in Node.js
}
// ...
}
எடுத்துக்காட்டாக, பின்வரும் அமைப்பு ஸ்கிரிப்ட்டைக் கொண்டு உங்கள் சோதனையில் உள்ள அனைத்து fetch()
அழைப்புகளையும் மாற்றியமைக்க விரும்பினால்:
import { fn } from '@wdio/browser-runner'
// run code before all tests are loaded
window.fetch = fn()
export const mochaGlobalSetup = () => {
// run code after test file is loaded
}
export const mochaGlobalTeardown = () => {
// run code after spec file was executed
}
இப்போது உங்கள் சோதனைகளில் நீங்கள் அனைத்து உலாவி கோரிக்கைகளுக்கும் தனிப்பயன் பதில் மதிப்புகளை வழங்கலாம். உலகளாவிய பிக்ஸ்ச்சர்கள் பற்றி Mocha ஆவணங்களில் மேலும் படிக்கவும்.