முக்கிய உள்ளடக்கத்திற்குச் செல்லவும்

திறன்கள்

ஒரு திறன் என்பது ஒரு தொலைநிலை இடைமுகத்திற்கான வரையறையாகும். இது WebdriverIO உங்கள் சோதனைகளை எந்த உலாவி அல்லது மொபைல் சூழலில் இயக்க விரும்புகிறீர்கள் என்பதை புரிந்துகொள்ள உதவுகிறது. உள்ளூரில் சோதனைகளை உருவாக்கும்போது திறன்கள் அவ்வளவு முக்கியமானதாக இல்லை, ஏனெனில் நீங்கள் பெரும்பாலும் ஒரு தொலைநிலை இடைமுகத்தில் மட்டுமே இயக்குவீர்கள், ஆனால் CI/CD-இல் பெரிய அளவிலான ஒருங்கிணைப்பு சோதனைகளை இயக்கும்போது இது மிகவும் முக்கியமானதாகிறது.

தகவல்

ஒரு திறன் பொருளின் வடிவம் WebDriver விவரக்குறிப்பு மூலம் நன்கு வரையறுக்கப்பட்டுள்ளது. பயனர் வரையறுக்கப்பட்ட திறன்கள் அந்த விவரக்குறிப்புகளுக்கு ஏற்ப இல்லையெனில் WebdriverIO டெஸ்ட்ரன்னர் ஆரம்பத்திலேயே தோல்வியடையும்.

தனிப்பயன் திறன்கள்

நிலையான வரையறுக்கப்பட்ட திறன்களின் எண்ணிக்கை மிகக் குறைவாக இருந்தாலும், ஒவ்வொருவரும் தானியங்கு இயக்கி அல்லது தொலைநிலை இடைமுகத்திற்கு குறிப்பிட்ட தனிப்பயன் திறன்களை வழங்கலாம் மற்றும் ஏற்றுக்கொள்ளலாம்:

உலாவி குறிப்பிட்ட திறன் நீட்டிப்புகள்

  • goog:chromeOptions: Chromedriver நீட்டிப்புகள், Chrome-இல் சோதனைக்கு மட்டுமே பொருந்தும்
  • moz:firefoxOptions: Geckodriver நீட்டிப்புகள், Firefox-இல் சோதனைக்கு மட்டுமே பொருந்தும்
  • ms:edgeOptions: EdgeOptions Chromium Edge சோதனைக்கான சூழலை குறிப்பிடுவதற்கு EdgeDriver பயன்படுத்தும்போது

கிளவுட் விற்பனையாளர் திறன் நீட்டிப்புகள்

தானியங்கு இயந்திர திறன் நீட்டிப்புகள்

  • appium:xxx: Appium
  • selenoid:xxx: Selenoid
  • மற்றும் பல...

உலாவி இயக்கி விருப்பங்களை நிர்வகிக்க WebdriverIO திறன்கள்

WebdriverIO உங்களுக்காக உலாவி இயக்கிகளை நிறுவி இயக்குவதை நிர்வகிக்கிறது. WebdriverIO இயக்கிக்கு அளவுருக்களை அனுப்ப அனுமதிக்கும் தனிப்பயன் திறனைப் பயன்படுத்துகிறது.

wdio:chromedriverOptions

Chromedriver தொடங்கும் போது அதற்கு அனுப்பப்படும் குறிப்பிட்ட விருப்பங்கள்.

wdio:geckodriverOptions

Geckodriver தொடங்கும் போது அதற்கு அனுப்பப்படும் குறிப்பிட்ட விருப்பங்கள்.

wdio:edgedriverOptions

Edgedriver தொடங்கும் போது அதற்கு அனுப்பப்படும் குறிப்பிட்ட விருப்பங்கள்.

wdio:safaridriverOptions

Safari தொடங்கும் போது அதற்கு அனுப்பப்படும் குறிப்பிட்ட விருப்பங்கள்.

wdio:maxInstances

குறிப்பிட்ட உலாவி/திறனுக்கான அதிகபட்ச மொத்த இணை இயங்கும் பணியாளர்களின் எண்ணிக்கை. maxInstances மற்றும் maxInstancesPerCapability ஐ விட முன்னுரிமை பெறுகிறது.

வகை: number

wdio:specs

அந்த உலாவி/திறனுக்கான சோதனை செயலாக்கத்திற்கான specs ஐ வரையறுக்கவும். வழக்கமான specs கட்டமைப்பு விருப்பம் போலவே, ஆனால் உலாவி/திறனுக்கு குறிப்பிட்டது. specs ஐ விட முன்னுரிமை பெறுகிறது.

வகை: (String | String[])[]

wdio:exclude

அந்த உலாவி/திறனுக்கான சோதனை செயலாக்கத்திலிருந்து specs ஐ விலக்கவும். வழக்கமான exclude கட்டமைப்பு விருப்பம் போலவே, ஆனால் உலாவி/திறனுக்கு குறிப்பிட்டது. உலகளாவிய exclude கட்டமைப்பு விருப்பம் பயன்படுத்தப்பட்ட பின்னர் விலக்குகிறது.

வகை: String[]

wdio:enforceWebDriverClassic

இயல்பாக, WebdriverIO WebDriver Bidi அமர்வை நிறுவ முயற்சிக்கிறது. நீங்கள் அதை விரும்பவில்லை என்றால், இந்த கொடியை அமைத்து இந்த நடத்தையை முடக்கலாம்.

வகை: boolean

பொதுவான இயக்கி விருப்பங்கள்

அனைத்து இயக்கிகளும் கட்டமைப்புக்கான வெவ்வேறு அளவுருக்களை வழங்கும் போது, WebdriverIO புரிந்துகொண்டு உங்கள் இயக்கி அல்லது உலாவியை அமைக்க பயன்படுத்தும் சில பொதுவானவை உள்ளன:

cacheDir

கேச் கோப்பகத்தின் ரூட்டுக்கான பாதை. இந்த கோப்பகம் ஒரு அமர்வைத் தொடங்க முயற்சிக்கும்போது பதிவிறக்கம் செய்யப்படும் அனைத்து இயக்கிகளையும் சேமிக்கப் பயன்படுகிறது.

வகை: string
இயல்பு: process.env.WEBDRIVER_CACHE_DIR || os.tmpdir()

binary

தனிப்பயன் இயக்கி பைனரிக்கான பாதை. அமைக்கப்பட்டால் WebdriverIO ஒரு இயக்கியை பதிவிறக்க முயற்சிக்காது, ஆனால் இந்த பாதையால் வழங்கப்படும் ஒன்றைப் பயன்படுத்தும். இயக்கி நீங்கள் பயன்படுத்தும் உலாவியுடன் இணக்கமானதாக இருப்பதை உறுதி செய்யவும்.

இந்த பாதையை CHROMEDRIVER_PATH, GECKODRIVER_PATH அல்லது EDGEDRIVER_PATH சுற்றுச்சூழல் மாறிகள் மூலம் வழங்கலாம்.

வகை: string

எச்சரிக்கை

இயக்கி binary அமைக்கப்பட்டிருந்தால், WebdriverIO ஒரு இயக்கியை பதிவிறக்க முயற்சிக்காது, ஆனால் இந்த பாதையால் வழங்கப்படும் ஒன்றைப் பயன்படுத்தும். இயக்கி நீங்கள் பயன்படுத்தும் உலாவியுடன் இணக்கமானதாக இருப்பதை உறுதி செய்யவும்.

உலாவி குறிப்பிட்ட இயக்கி விருப்பங்கள்

இயக்கிக்கு விருப்பங்களை வழங்க, நீங்கள் பின்வரும் தனிப்பயன் திறன்களைப் பயன்படுத்தலாம்:

  • Chrome அல்லது Chromium: wdio:chromedriverOptions
  • Firefox: wdio:geckodriverOptions
  • Microsoft Egde: wdio:edgedriverOptions
  • Safari: wdio:safaridriverOptions
adbPort

ADB இயக்கி இயங்க வேண்டிய போர்ட்.

உதாரணம்: 9515

வகை: number

urlBase

கட்டளைகளுக்கான அடிப்படை URL பாதை முன்னொட்டு, எ.கா. wd/url.

உதாரணம்: /

வகை: string

logPath

stderr-க்கு பதிலாக கோப்பிற்கு சர்வர் பதிவை எழுதவும், பதிவு நிலையை INFO ஆக அதிகரிக்கிறது

வகை: string

logLevel

பதிவு நிலையை அமைக்கவும். சாத்தியமான விருப்பங்கள் ALL, DEBUG, INFO, WARNING, SEVERE, OFF.

வகை: string

verbose

விரிவாக பதிவு செய்யவும் (--log-level=ALL-க்கு சமமானது)

வகை: boolean

silent

எதுவும் பதிவு செய்ய வேண்டாம் (--log-level=OFF-க்கு சமமானது)

வகை: boolean

appendLog

பதிவு கோப்பை மறுஎழுதுவதற்கு பதிலாக சேர்க்கவும்.

வகை: boolean

replayable

விரிவாக பதிவு செய்து நீண்ட சரங்களை துண்டிக்க வேண்டாம், இதனால் பதிவை மறுபடியும் இயக்க முடியும் (பரிசோதனை).

வகை: boolean

readableTimestamp

பதிவுக்கு படிக்கக்கூடிய நேர முத்திரைகளைச் சேர்க்கவும்.

வகை: boolean

enableChromeLogs

உலாவியிலிருந்து பதிவுகளைக் காட்டவும் (மற்ற பதிவு விருப்பங்களை மேலெழுதுகிறது).

வகை: boolean

bidiMapperPath

தனிப்பயன் bidi மேப்பர் பாதை.

வகை: string

allowedIps

EdgeDriver-க்கு இணைக்க அனுமதிக்கப்பட்ட தொலைநிலை IP முகவரிகளின் காற்புள்ளியால் பிரிக்கப்பட்ட அனுமதிப்பட்டியல்.

வகை: string[]
இயல்பு: ['']

allowedOrigins

EdgeDriver-க்கு இணைக்க அனுமதிக்கப்பட்ட கோரிக்கை தோற்றங்களின் காற்புள்ளியால் பிரிக்கப்பட்ட அனுமதிப்பட்டியல். எந்த ஹோஸ்ட் தோற்றத்தையும் அனுமதிக்க * ஐப் பயன்படுத்துவது ஆபத்தானது!

வகை: string[]
இயல்பு: ['*']

spawnOpts

இயக்கி செயல்முறைக்கு அனுப்பப்படும் விருப்பங்கள்.

வகை: SpawnOptionsWithoutStdio | SpawnOptionsWithStdioTuple<StdioOption, StdioOption, StdioOption>
இயல்பு: undefined

குறிப்பிட்ட பயன்பாட்டு வழக்குகளுக்கான சிறப்பு திறன்கள்

இது ஒரு குறிப்பிட்ட பயன்பாட்டு வழக்கை அடைய எந்த திறன்களைப் பயன்படுத்த வேண்டும் என்பதைக் காட்டும் உதாரணங்களின் பட்டியல்.

உலாவியை ஹெட்லெஸ் இயக்குதல்

ஹெட்லெஸ் உலாவியை இயக்குவது என்பது சாளரம் அல்லது UI இல்லாமல் ஒரு உலாவி நிகழ்வை இயக்குவதாகும். இது பெரும்பாலும் காட்சி பயன்படுத்தப்படாத CI/CD சூழல்களில் பயன்படுத்தப்படுகிறது. ஹெட்லெஸ் பயன்முறையில் உலாவியை இயக்க, பின்வரும் திறன்களைப் பயன்படுத்தவும்:

{
browserName: 'chrome', // அல்லது 'chromium'
'goog:chromeOptions': {
args: ['headless', 'disable-gpu']
}
}

வெவ்வேறு உலாவி சேனல்களை தானியங்குபடுத்துதல்

நிலையான பதிப்பாக இன்னும் வெளியிடப்படாத உலாவி பதிப்பை நீங்கள் சோதிக்க விரும்பினால், எ.கா. Chrome Canary, நீங்கள் திறன்களை அமைத்து நீங்கள் தொடங்க விரும்பும் உலாவியைச் சுட்டிக்காட்டி இதைச் செய்யலாம், எ.கா.:

Chrome-இல் சோதிக்கும் போது, WebdriverIO வரையறுக்கப்பட்ட browserVersion-ன் அடிப்படையில் விரும்பிய உலாவி பதிப்பு மற்றும் இயக்கியை தானாகவே பதிவிறக்கும், எ.கா.:

{
browserName: 'chrome', // அல்லது 'chromium'
browserVersion: '116' // அல்லது '116.0.5845.96', 'stable', 'dev', 'canary', 'beta' அல்லது 'latest' ('canary' போன்றது)
}

கைமுறையாக பதிவிறக்கப்பட்ட உலாவியை நீங்கள் சோதிக்க விரும்பினால், உலாவிக்கான பைனரி பாதையை வழங்கலாம்:

{
browserName: 'chrome', // அல்லது 'chromium'
'goog:chromeOptions': {
binary: '/Applications/Google\ Chrome\ Canary.app/Contents/MacOS/Google\ Chrome\ Canary'
}
}

கூடுதலாக, கைமுறையாக பதிவிறக்கப்பட்ட இயக்கியைப் பயன்படுத்த விரும்பினால், இயக்கிக்கான பைனரி பாதையை வழங்கலாம்:

{
browserName: 'chrome', // அல்லது 'chromium'
'wdio:chromedriverOptions': {
binary: '/path/to/chromdriver'
}
}

தனிப்பயன் திறன்களை நீட்டிக்கவும்

உங்கள் சொந்த திறன்களை வரையறுக்க விரும்பினால், எ.கா. அந்த குறிப்பிட்ட திறனுக்கான சோதனைகளில் பயன்படுத்த தன்னிச்சையான தரவை சேமிக்க, நீங்கள் இவ்வாறு செய்யலாம்:

export const config = {
// ...
capabilities: [{
browserName: 'chrome',
'custom:caps': {
// தனிப்பயன் கட்டமைப்புகள்
}
}]
}

திறன் பெயரிடலில் W3C நெறிமுறையை பின்பற்ற அறிவுறுத்தப்படுகிறது, இதற்கு : (கோலன்) எழுத்து தேவைப்படுகிறது, இது ஒரு குறிப்பிட்ட செயல்படுத்தல் நேம்ஸ்பேஸைக் குறிக்கிறது. உங்கள் சோதனைகளில் உங்கள் தனிப்பயன் திறனை அணுகலாம், எ.கா.:

browser.capabilities['custom:caps']

வகை பாதுகாப்பை உறுதிசெய்ய, WebdriverIO திறன் இடைமுகத்தை நீட்டிக்கலாம்:

declare global {
namespace WebdriverIO {
interface Capabilities {
'custom:caps': {
// ...
}
}
}
}

Welcome! How can I help?

WebdriverIO AI Copilot