திட்டரூபங்கள்
WebdriverIO Runner-க்கு Mocha, Jasmine, மற்றும் Cucumber.js ஆகியவற்றுக்கான உள்ளமைக்கப்பட்ட ஆதரவு உள்ளது. நீங்கள் Serenity/JS போன்ற மூன்றாம் தரப்பு திறந்த மூல திட்டரூபங்களுடன் அதை ஒருங்கிணைக்கலாம்.
WebdriverIO-வை ஒரு சோதனை திட்டரூபத்துடன் ஒருங்கிணைக்க, NPM-இல் கிடைக்கும் ஒரு அடாப்டர் தொகுப்பு தேவைப்படுகிறது. அடாப்டர் தொகுப்பு WebdriverIO நிறுவப்பட்டிருக்கும் அதே இடத்தில் நிறுவப்பட வேண்டும் என்பதை நினைவில் கொள்ளவும். எனவே, நீங்கள் WebdriverIO-வை உலகளாவிய அளவில் நிறுவியிருந்தால், அடாப்டர் தொகுப்பையும் உலகளாவிய அளவில் நிறுவ உறுதிசெய்து கொள்ளுங்கள்.
WebdriverIO-வை ஒரு சோதனை திட்டரூபத்துடன் ஒருங்கிணைப்பது உங்கள் spec கோப்புகள் அல்லது step definitions-இல் உலகளாவிய browser
மாறி மூலம் WebDriver நிகழ்நிலையை அணுக அனுமதிக்கிறது.
WebdriverIO செலீனியம் அமர்வைத் தொடங்குவதற்கும் முடிப்பதற்கும் கவனித்துக்கொள்ளும், எனவே நீங்கள் அதைச் செய்ய வேண்டியதில்லை என்பதை நினைவில் கொள்ளவும்.
Mocha-வைப் பயன்படுத்துதல்
முதலில், NPM இலிருந்து அடாப்டர் தொகுப்பை நிறுவவும்:
- npm
- Yarn
- pnpm
npm install @wdio/mocha-framework --save-dev
yarn add @wdio/mocha-framework --dev
pnpm add @wdio/mocha-framework --save-dev
இயல்பாக WebdriverIO ஒரு assertion library வழங்குகிறது, இது உள்ளமைக்கப்பட்டுள்ளது மற்றும் நீங்கள் உடனடியாக தொடங்கலாம்:
describe('my awesome website', () => {
it('should do some assertions', async () => {
await browser.url('https://webdriver.io')
await expect(browser).toHaveTitle('WebdriverIO · Next-gen browser and mobile automation test framework for Node.js | WebdriverIO')
})
})
WebdriverIO, Mocha-வின் BDD
(இயல்பு), TDD
, மற்றும் QUnit
interfaces ஆதரிக்கிறது.
நீங்கள் உங்கள் specs-ஐ TDD பாணியில் எழுத விரும்பினால், உங்கள் mochaOpts
உள்ளமைவில் ui
பண்புக்கு tdd
என அமைக்கவும். இப்போது உங்கள் சோதனை கோப்புகள் இப்படி எழுதப்பட வேண்டும்:
suite('my awesome website', () => {
test('should do some assertions', async () => {
await browser.url('https://webdriver.io')
await expect(browser).toHaveTitle('WebdriverIO · Next-gen browser and mobile automation test framework for Node.js | WebdriverIO')
})
})
நீங்கள் மற்ற Mocha-குறிப்பிட்ட அமைப்புகளை வரையறுக்க விரும்பினால், உங்கள் உள்ளமைவு கோப்பில் mochaOpts
விசை மூலம் செய்யலாம். அனைத்து விருப்பங்களின் பட்டியலை Mocha திட்ட இணையதளத்தில் காணலாம்.
குறிப்பு: WebdriverIO Mocha-வில் done
callbacks-இன் பழமையான பயன்பாட்டை ஆதரிக்காது:
it('should test something', (done) => {
done() // throws "done is not a function"
})
Mocha விருப்பங்கள்
உங்கள் Mocha சூழலை உள்ளமைக்க பின்வரும் விருப்பங்களை உங்கள் wdio.conf.js
-இல் பயன்படுத்தலாம். குறிப்பு: அனைத்து விருப்பங்களும் ஆதரிக்கப்படவில்லை, எ.கா. parallel
விருப்பத்தைப் பயன்படுத்துவது பிழையை ஏற்படுத்தும், ஏனெனில் WDIO சோதனை செயல்படுத்தி சோதனைகளை இணையாக இயக்க அதற்கென்று ஒரு வழி உள்ளது. நீங்கள் இந்த திட்டரூப விருப்பங்களை arguments-ஆக அனுப்பலாம், எ.கா.:
wdio run wdio.conf.ts --mochaOpts.grep "my test" --mochaOpts.bail --no-mochaOpts.checkLeaks
இது பின்வரும் Mocha விருப்பங்களை அனுப்பும்:
{
grep: ['my-test'],
bail: true
checkLeacks: false
}
பின்வரும் Mocha விருப்பங்கள் ஆதரிக்கப்படுகின்றன:
require
require
விருப்பமானது சில அடிப்படை செயல்பாடுகளைச் சேர்க்க அல்லது விரிவாக்க விரும்பும்போது பயனுள்ளதாக இருக்கும் (WebdriverIO திட்டரூப விருப்பம்).
வகை: string|string[]
இயல்பு: []
compilers
கோப்புகளைத் தொகுக்க கொடுக்கப்பட்ட தொகுதி(களை)ப் பயன்படுத்தவும். requires-க்கு முன் Compilers சேர்க்கப்படும் (WebdriverIO திட்டரூப விருப்பம்).
வகை: string[]
இயல்பு: []
allowUncaught
கைப்பற்றப்படாத பிழைகளைப் பரப்பவும்.
வகை: boolean
இயல்பு: false
bail
முதல் சோதனை தோல்வியடைந்த பிறகு bail ஆகும்.
வகை: boolean
இயல்பு: false
checkLeaks
உலகளாவிய மாறி கசிவுகளை சரிபார்க்கவும்.
வகை: boolean
இயல்பு: false
delay
மூல தொகுப்பு செயல்பாட்டைத் தாமதப்படுத்துங்கள்.
வகை: boolean
இயல்பு: false
fgrep
கொடுக்கப்பட்ட சரத்தைக் கொண்டு சோதனை வடிகட்டி.
வகை: string
இயல்பு: null
forbidOnly
only
என குறிக்கப்பட்ட சோதனைகள் தொகுப்பைத் தோல்வியடையச் செய்யும்.
வகை: boolean
இயல்பு: false
forbidPending
நிலுவையிலுள்ள சோதனைகள் தொகுப்பைத் தோல்வியடையச் செய்யும்.
வகை: boolean
இயல்பு: false
fullTrace
தோல்வியின் போது முழு stacktrace.
வகை: boolean
இயல்பு: false
global
உலகளாவிய நோக்கில் எதிர்பார்க்கப்படும் மாறிகள்.
வகை: string[]
இயல்பு: []
grep
கொடுக்கப்பட்ட வழக்கமான வெளிப்பாட்டைக் கொண்டு சோதனை வடிகட்டி.
வகை: RegExp|string
இயல்பு: null
invert
சோதனை வடிகட்டி பொருத்தங்களை புரட்டவும்.
வகை: boolean
இயல்பு: false
retries
தோல்வியடைந்த சோதனைகளை மறுமுயற்சி செய்வதற்கான எண்ணிக்கை.
வகை: number
இயல்பு: 0
timeout
நேர முடிவு வரம்பு மதிப்பு (மில்லிவினாடிகளில்).
வகை: number
இயல்பு: 30000
Jasmine-ஐப் பயன்படுத்துதல்
முதலில், NPM இலிருந்து அடாப்டர் தொகுப்பை நிறுவவும்:
- npm
- Yarn
- pnpm
npm install @wdio/jasmine-framework --save-dev
yarn add @wdio/jasmine-framework --dev
pnpm add @wdio/jasmine-framework --save-dev
உங்கள் config-இல் jasmineOpts
பண்பை அமைப்பதன் மூலம் நீங்கள் உங்கள் Jasmine சூழலை உள்ளமைக்கலாம். அனைத்து விருப்பங்களின் பட்டியலை Jasmine திட்ட இணையதளத்தில் காணலாம்.
Jasmine விருப்பங்கள்
jasmineOpts
பண்பைப் பயன்படுத்தி உங்கள் Jasmine சூழலை உள்ளமைக்க பின்வரும் விருப்பங்களை உங்கள் wdio.conf.js
இல் பயன்படுத்தலாம். இந்த உள்ளமைவு விருப்பங்கள் பற்றிய கூடுதல் தகவலுக்கு, Jasmine ஆவணங்களை பார்க்கவும். நீங்கள் இந்த திட்டரூப விருப்பங்களை arguments-ஆக அனுப்பலாம், எ.கா.:
wdio run wdio.conf.ts --jasmineOpts.grep "my test" --jasmineOpts.failSpecWithNoExpectations --no-jasmineOpts.random
இது பின்வரும் Mocha விருப்பங்களை அனுப்பும்:
{
grep: ['my-test'],
bail: true
checkLeacks: false
}
பின்வரும் Jasmine விருப்பங்கள் ஆதரிக்கப்படுகின்றன:
defaultTimeoutInterval
Jasmine செயல்பாடுகளுக்கான இயல்புநிலை நேர முடிவு இடைவெளி.
வகை: number
இயல்பு: 60000
helpers
Jasmine specs-க்கு முன் சேர்க்க spec_dir-க்கு தொடர்புடைய கோப்பு பாதைகளின் அணி (மற்றும் globs).
வகை: string[]
இயல்பு: []
requires
சில அடிப்படை செயல்பாடுகளைச் சேர்க்க அல்லது விரிவாக்க விரும்பும்போது requires
விருப்பம் பயனுள்ளதாக இருக்கும்.
வகை: string[]
இயல்பு: []
random
spec செயல்படுத்துதல் வரிசையை சீரற்றதாக்க வேண்டுமா.
வகை: boolean
இயல்பு: true
seed
சீரற்ற தன்மையின் அடிப்படையாகப் பயன்படுத்த seed. Null என்பது செயல்பாட்டின் தொடக்கத்தில் seed சீரற்றதாக தீர்மானிக்கப்படுவதற்கு காரணமாகிறது.
வகை: Function
இயல்பு: null
failSpecWithNoExpectations
எந்த எதிர்பார்ப்புகளையும் இயக்காத spec-ஐ தோல்வியடையச் செய்ய வேண்டுமா. இயல்பாக எந்த எதிர்பார்ப்புகளையும் இயக்காத spec வெற்றியடைந்ததாக அறிக்கையிடப்படுகிறது. இதை true என அமைப்பது அத்தகைய spec-ஐ தோல்வியாக அறிக்கையிடும்.
வகை: boolean
இயல்பு: false
oneFailurePerSpec
Specs-க்கு ஒரே ஒரு எதிர்பார்ப்பு தோல்வி மட்டுமே இருக்க வேண்டுமா.
வகை: boolean
இயல்பு: false
specFilter
Specs-ஐ வடிகட்ட பயன்படுத்த வேண்டிய செயல்பாடு.
வகை: Function
இயல்பு: (spec) => true
grep
இந்த சரம் அல்லது regexp-உடன் பொருந்தும் சோதனைகளை மட்டும் இயக்கவும். (தனிப்பயன் specFilter
செயல்பாடு அமைக்கப்படவில்லை என்றால் மட்டுமே பொருந்தும்)
வகை: string|Regexp
இயல்பு: null
invertGrep
இது உண்மையாக இருந்தால், அது பொருந்தும் சோதனைகளைத் தலைகீழாக்கி, grep
-இல் பயன்படுத்தப்படும் வெளிப்பாட்டுடன் பொருந்தாத சோதனைகளை மட்டுமே இயக்குகிறது. (தனிப்பயன் specFilter
செயல்பாடு அமைக்கப்படவில்லை என்றால் மட்டுமே பொருந்தும்)
வகை: boolean
இயல்பு: false
Cucumber-ஐப் பயன்படுத்துதல்
முதலில், NPM இலிருந்து அடாப்டர் தொகுப்பை நிறுவவும்:
- npm
- Yarn
- pnpm
npm install @wdio/cucumber-framework --save-dev
yarn add @wdio/cucumber-framework --dev
pnpm add @wdio/cucumber-framework --save-dev
நீங்கள் Cucumber-ஐப் பயன்படுத்த விரும்பினால், config file-க்கு framework: 'cucumber'
-ஐச் சேர்ப்பதன் மூலம் framework
பண்பை cucumber
என அமைக்கவும்.
Cucumber-க்கான விருப்பங்களை cucumberOpts
-உடன் உள்ளமைவு கோப்பில் வழங்கலாம். விருப்பங்களின் முழு பட்டியலை இங்கே பார்க்கவும்.
Cucumber-உடன் விரைவாக இயங்கத் தொடங்க, நீங்கள் தொடங்குவதற்குத் தேவையான அனைத்து step definitions-உடனும் வரும் எங்களின் cucumber-boilerplate
திட்டத்தைப் பார்வையிடவும், மேலும் நீங்கள் உடனடியாக அம்சக் கோப்புகளை எழுதத் தொடங்குவீர்கள்.
Cucumber விருப்பங்கள்
cucumberOpts
பண்பைப் பயன்படுத்தி உங்கள் Cucumber சூழலை உள்ளமைக்க, பின்வரும் விருப்பங்களை உங்கள் wdio.conf.js
இல் பயன்படுத்தலாம்:
cucumberOpts
, சோதனைகளை வடிகட்டுவதற்கான தனிப்பயன் tags
போன்ற, கட்டளை வரி மூலமாக குறிப்பிடமுடியும். இது cucumberOpts.{optionName}="value"
வடிவத்தைப் பயன்படுத்தி செய்யப்படுகிறது.
எடுத்துக்காட்டாக, நீங்கள் @smoke
குறிச்சொல்லைக் கொண்ட சோதனைகளை மட்டும் இயக்க விரும்பினால், பின்வரும் கட்டளையைப் பயன்படுத்தலாம்:
# When you only want to run tests that hold the tag "@smoke"
npx wdio run ./wdio.conf.js --cucumberOpts.tags="@smoke"
npx wdio run ./wdio.conf.js --cucumberOpts.name="some scenario name" --cucumberOpts.failFast
இந்த கட்டளை cucumberOpts
-இல் tags
விருப்பத்தை @smoke
என அமைக்கிறது, இது இந்த குறிச்சொல் கொண்ட சோதனைகள் மட்டுமே இயக்கப்படுவதை உறுதிசெய்கிறது.
backtrace
பிழைகளுக்கான முழு backtrace-ஐக் காட்டவும்.
வகை: Boolean
இயல்பு: true
requireModule
ஏதேனும் ஆதரவு கோப்புகளைத் தேவைப்படுத்தும் முன் தொகுதிகளைத் தேவைப்படுத்துங்கள்.
வகை: string[]
இயல்பு: []
உதாரணம்:
cucumberOpts: {
requireModule: ['@babel/register']
// or
requireModule: [
[
'@babel/register',
{
rootMode: 'upward',
ignore: ['node_modules']
}
]
]
}
failFast
முதல் தோல்வியில் ஓட்டத்தை நிறுத்தவும்.
வகை: boolean
இயல்பு: false
name
வெளிப்பாட்டுடன் பொருந்தும் பெயரைக் கொண்ட சிக்கல்களை மட்டும் இயக்கவும் (மீண்டும் செய்யக்கூடியது).
வகை: RegExp[]
இயல்பு: []
require
அம்சங்களைச் செயல்படுத்தும் முன் உங்கள் step definitions கொண்ட கோப்புகளைத் தேவைப்படுத்துங்கள். நீங்கள் உங்கள் step definitions-க்கு glob-ஐயும் குறிப்பிடலாம்.
வகை: string[]
இயல்பு: []
உதாரணம்:
cucumberOpts: {
require: [path.join(__dirname, 'step-definitions', 'my-steps.js')]
}
import
ESM-க்காக உங்கள் ஆதரவு குறியீடு உள்ள இடங்களுக்கான பாதைகள்.
வகை: String[]
இயல்பு: []
உதாரணம்:
cucumberOpts: {
import: [path.join(__dirname, 'step-definitions', 'my-steps.js')]
}
strict
வரையறுக்கப்படாத அல்லது நிலுவையிலுள்ள எந்த படிகளும் இருந்தால் தோல்வியடையும்.
வகை: boolean
இயல்பு: false
tags
வெளிப்பாட்டுடன் பொருந்தும் குறிச்சொற்களைக் கொண்ட அம்சங்கள் அல்லது சிக்கல்களை மட்டும் இயக்கவும். மேலும் விவரங்களுக்கு Cucumber ஆவணங்களைப் பார்க்கவும்.
வகை: String
இயல்பு: ``
timeout
Step definitions-க்கான நேர முடிவு மில்லிவினாடிகளில்.
வகை: Number
இயல்பு: 30000
retry
தோல்வியடையும் சோதனை வழக்குகளை எத்தனை முறை மறுமுயற்சி செய்ய வேண்டும் என்பதைக் குறிப்பிடவும்.
வகை: Number
இயல்பு: 0
retryTagFilter
வெளிப்பாட்டுடன் பொருந்தும் குறிச்சொற்களைக் கொண்ட அம்சங்கள் அல்லது சிக்கல்களை மட்டுமே மீண்டும் முயற்சிக்கவும் (மீண்டும் செய்யக்கூடியது). இந்த விருப்பத்திற்கு '--retry' குறிப்பிடப்பட வேண்டும்.
வகை: RegExp
language
உங்கள் அம்ச கோப்புகளுக்கான இயல்பு மொழி
வகை: String
இயல்பு: en
order
சோதனைகளை வரையறுக்கப்பட்ட / சீரற்ற வரிசையில் இயக்கவும்
வகை: String
இயல்பு: defined
format
பயன்படுத்த வடிவமைப்பாளரின் பெயர் மற்றும் வெளியீட்டு கோப்பு பாதை. WebdriverIO முதன்மையாக ஒரு கோப்பில் வெளியீட்டை எழுதும் Formatters மட்டுமே ஆதரிக்கிறது.
வகை: string[]
formatOptions
வடிவமைப்பாளர்களுக்கு வழங்க வேண்டிய விருப்பங்கள்
வகை: object
tagsInTitle
அம்சம் அல்லது சிக்கல் பெயருக்கு cucumber tags சேர்க்கவும்
வகை: Boolean
இயல்பு: false
இது ஒரு @wdio/cucumber-framework-குறிப்பிட்ட விருப்பம் என்பதையும், cucumber-js-ஆல் அங்கீகரிக்கப்படவில்லை என்பதையும் நினைவில் கொள்ளவும்
ignoreUndefinedDefinitions
வரையறுக்கப்படாத வரையறைகளை எச்சரிக்கைகளாக நடத்துங்கள்.
வகை: Boolean
இயல்பு: false
இது ஒரு @wdio/cucumber-framework-குறிப்பிட்ட விருப்பம் என்பதையும், cucumber-js-ஆல் அங்கீகரிக்கப்படவில்லை என்பதையும் நினைவில் கொள்ளவும்
failAmbiguousDefinitions
தெளிவற்ற வரையறைகளை பிழைகளாக நடத்துங்கள்.
வகை: Boolean
இயல்பு: false
இது ஒரு @wdio/cucumber-framework-குறிப்பிட்ட விருப்பம் என்பதையும், cucumber-js-ஆல் அங்கீகரிக்கப்படவில்லை என்பதையும் நினைவில் கொள்ளவும்
tagExpression
வெளிப்பாட்டுடன் பொருந்தும் குறிச்சொற்களைக் கொண்ட அம்சங்கள் அல்லது சிக்கல்களை மட்டும் இயக்கவும். மேலும் விவரங்களுக்கு Cucumber ஆவணங்களைப் பார்க்கவும்.
வகை: String
இயல்பு: ``
இந்த விருப்பம் எதிர்காலத்தில் மறுபயனாக்கப்படும் என்பதை நினைவில் கொள்ளவும். அதற்கு பதிலாக tags
config property-ஐப் பயன்படுத்தவும்
profile
பயன்படுத்த வேண்டிய சுயவிவரத்தைக் குறிப்பிடவும்.
வகை: string[]
இயல்பு: []
cucumberOpts
முன்னுரிமையைக் கொண்டிருப்பதால், சுயவிவரங்களுக்குள் குறிப்பிட்ட மதிப்புகள் (worldParameters, name, retryTagFilter) மட்டுமே ஆதரிக்கப்படுகின்றன என்பதை கவனமாக கவனிக்கவும். கூடுதலாக, ஒரு சுயவிவரத்தைப் பயன்படுத்தும்போது, குறிப்பிடப்பட்ட மதிப்புகள் cucumberOpts
-க்குள் அறிவிக்கப்படவில்லை என்பதை உறுதிசெய்து கொள்ளுங்கள்.
Cucumber-இல் சோதனைகளைத் தவிர்த்தல்
cucumberOpts
இல் கிடைக்கும் வழக்கமான cucumber சோதனை வடிகட்டல் திறன்களைப் பயன்படுத்தி ஒரு சோதனையைத் தவிர்க்க விரும்பினால், நீங்கள் உள்ளமைவில் உள்ள அனைத்து உலாவிகள் மற்றும் சாதனங்களுக்கும் அதைச் செய்வீர்கள் என்பதை கவனிக்கவும். தேவைப்பட்டால் ஒரு அமர்வைத் தொடங்காமல் குறிப்பிட்ட திறன்கள் சேர்க்கைகளுக்கு மட்டும் சிக்கல்களைத் தவிர்க்க முடியும்படி, webdriverio cucumber-க்கான பின்வரும் குறிப்பிட்ட குறிச்சொல் தொடரியலை வழங்குகிறது:
@skip([condition])
condition என்பது, அனைத்தும் பொருந்தும்போது, குறிக்கப்பட்ட சிக்கல் அல்லது அம்சத்தைத் தவிர்க்க காரணமாகும் capabilities பண்புகளின் விருப்பமான சேர்க்கை ஆகும். நிச்சயமாக நீங்கள் பல்வேறு நிபந்தனைகளின் கீழ் ஒரு சோதனைகளைத் தவிர்க்க, சிக்கல்கள் மற்றும் அம்சங்களுக்கு பல குறிச்சொற்களைச் சேர்க்கலாம்.
'tagExpression'-ஐ மாற்றாமல் சோதனைகளைத் தவிர்க்க '@skip' annotation-ஐயும் பயன்படுத்தலாம். இந்த நிகழ்வில் தவிர்க்கப்பட்ட சோதனைகள் சோதனை அறிக்கையில் காட்டப்படும்.
இந்த தொடரியலுக்கான சில உதாரணங்கள் இங்கே உள்ளன:
@skip
அல்லது@skip()
: குறிக்கப்பட்ட உருப்படியை எப்போதும் தவிர்க்கும்@skip(browserName="chrome")
: chrome உலாவிகளுக்கு எதிராக சோதனை இயக்கப்படாது.@skip(browserName="firefox";platformName="linux")
: லினக்ஸ் இயக்கங்களில் firefox-இல் சோதனையைத் தவிர்க்கும்.@skip(browserName=["chrome","firefox"])
: குறிக்கப்பட்ட உருப்படிகள் chrome மற்றும் firefox உலாவிகள் இரண்டிலும் தவிர்க்கப்படும்.@skip(browserName=/i.*explorer/)
: regexp-உடன் பொருந்தும் உலாவிகள் கொண்ட திறன்கள் தவிர்க்கப்படும் (போன்றiexplorer
,internet explorer
,internet-explorer
, ...).
Step Definition Helper ஐ இறக்குமதி செய்தல்
Given
, When
அல்லது Then
போன்ற step definition helper அல்லது hooks-ஐப் பயன்படுத்த, நீங்கள் அவற்றை @cucumber/cucumber
-இலிருந்து இறக்குமதி செய்ய வேண்டும், எ.கா. இப்படி:
import { Given, When, Then } from '@cucumber/cucumber'
இப்போது, WebdriverIO-வுடன் தொடர்பில்லாத பிற வகையான சோதனைகளுக்கு நீங்கள் ஏற்கனவே ஒரு குறிப்பிட்ட பதிப்பைப் பயன்படுத்தும் Cucumber-ஐப் பயன்படுத்தினால், உங்கள் e2e சோதனைகளில் இந்த helpers-ஐ WebdriverIO Cucumber தொகுப்பிலிருந்து இறக்குமதி செய்ய வேண்டும், எ.கா.:
import { Given, When, Then, world, context } from '@wdio/cucumber-framework'
இது WebdriverIO திட்டரூபத்திற்குள் நீங்கள் சரியான helpers-ஐப் பயன்படுத்துவதை உறுதிசெய்கிறது மற்றும் பிற வகையான சோதனைகளுக்கு ஒரு சுயாதீன Cucumber பதிப்பைப் பயன்படுத்த அனுமதிக்கிறது.
அறிக்கையை வெளியிடுதல்
Cucumber உங்கள் சோதனை ஓட்ட அறிக்கைகளை https://reports.cucumber.io/
இல் வெளியிடுவதற்கான அம்சத்தை வழங்குகிறது, இது cucumberOpts
இல் publish
கொடியை அமைப்பதன் மூலமாகவோ அல்லது CUCUMBER_PUBLISH_TOKEN
சூழல் மாறியை உள்ளமைப்பதன் மூலமாகவோ கட்டுப்படுத்தப்படலாம். இருப்பினும், சோதனை நிறைவேற்றத்திற்கு WebdriverIO
ஐப் பயன்படுத்தும்போது, இந்த அணுகுமுறையில் ஒரு வரம்பு உள்ளது. இது ஒவ்வொரு அம்ச கோப்புக்காகவும் தனித்தனியாக அறிக்கைகளைப் புதுப்பிக்கிறது, இது ஒரு ஒருங்கிணைந்த அறிக்கையைப் பார்ப்பதை கடினமாக்குகிறது.
இந்த வரம்பை சமாளிக்க, @wdio/cucumber-framework
க்குள் publishCucumberReport
என்ற promise அடிப்படையிலான முறையை அறிமுகப்படுத்தியுள்ளோம். இந்த முறையை onComplete
hook இல் அழைக்க வேண்டும், இது அதை அழைப்பதற்கான சிறந்த இடமாகும். publishCucumberReport
cucumber செய்தி அறிக்கைகள் சேமிக்கப்படும் அறிக்கை அடைவின் உள்ளீட்டைத் தேவைப்படுகிறது.
உங்கள் cucumberOpts
இல் format
விருப்பத்தை உள்ளமைப்பதன் மூலம் நீங்கள் cucumber செய்தி
அறிக்கைகளை உருவாக்கலாம். அறிக்கைகளை மேலெழுதுவதைத் தடுக்க மற்றும் ஒவ்வொரு சோதனை ஓட்டமும் துல்லியமாக பதிவு செய்யப்படுவதை உறுதிசெய்ய cucumber செய்தி
format விருப்பத்திற்குள் ஒரு dynamic கோப்பு பெயரை வழங்குவது பெரிதும் பரிந்துரைக்கப்படுகிறது.
இந்த செயல்பாட்டைப் பயன்படுத்துவதற்கு முன், பின்வரும் சூழல் மாறிகளை அமைக்கவும்:
- CUCUMBER_PUBLISH_REPORT_URL: நீங்கள் Cucumber அறிக்கையை வெளியிட விரும்பும் URL. வழங்கப்படவில்லை என்றால், இயல்பு URL 'https://messages.cucumber.io/api/reports' பயன்படுத்தப்படும்.
- CUCUMBER_PUBLISH_REPORT_TOKEN: அறிக்கையை வெளியிட தேவையான அங்கீகார டோக்கன். இந்த டோக்கன் அமைக்கப்படவில்லை என்றால், செயல்பாடு அறிக்கையை வெளியிடாமல் வெளியேறும்.
அமலாக்கத்திற்கான தேவையான உள்ளமைவுகள் மற்றும் குறியீடு மாதிரிகளின் உதாரணம் இங்கே:
import { v4 as uuidv4 } from 'uuid'
import { publishCucumberReport } from '@wdio/cucumber-framework';
export const config = {
// ... Other Configuration Options
cucumberOpts: {
// ... Cucumber Options Configuration
format: [
['message', `./reports/${uuidv4()}.ndjson`],
['json', './reports/test-report.json']
]
},
async onComplete() {
await publishCucumberReport('./reports');
}
}
./reports/
என்பது cucumber செய்தி
அறிக்கைகள் சேமிக்கப்படும் அடைவு என்பதை நினைவில் கொள்ளவும்.
Serenity/JS ஐப் பயன்படுத்துதல்
Serenity/JS என்பது சிக்கலான மென்பொருள் அமைப்புகளின் ஏற்பு மற்றும் பின்னோக்கி சோதனைகளை வேகமாகவும், கூடுதல் ஒத்துழைப்புடனும், அளவிடவும் எளிதாக்கவும் வடிவமைக்கப்பட்ட ஒரு திறந்த மூல திட்டரூபமாகும்.
WebdriverIO சோதனை தொகுப்புகளுக்கு, Serenity/JS பின்வருவனவற்றை வழங்குகிறது:
- Enhanced Reporting - உங்கள் திட்டத்தின் ஆழமான சோதனை நிறைவேற்ற அறிக்கைகள் மற்றும் உயிருள்ள ஆவணங்களை உருவாக்க நீங்கள் உள்ளமைக்கப்பட்ட எந்த WebdriverIO திட்டரூபத்திற்கும் Serenity/JS-ஐ drop-in மாற்றாகப் பயன்படுத்தலாம்.
- Screenplay Pattern APIs - உங்கள் சோதனை குறியீட்டை திட்டங்கள் மற்றும் குழுக்களில் சுமக்கக்கூடியதாகவும் மீண்டும் பயன்படுத்தக்கூடியதாகவும் மாற்ற, Serenity/JS உங்களுக்கு உள்ளார்ந்த WebdriverIO APIs மீது ஒரு விருப்பமான abstraction layer வழங்குகிறது.
- Integration Libraries - Screenplay Pattern பின்பற்றும் சோதனை தொகுப்புகளுக்கு, API சோதனைகள் எழுத, உள்ளூர் சேவையகங்களை நிர்வகிக்க, உறுதிப்பாடுகளை செய்ய, மற்றும் மேலும் பலவற்றிற்கு உதவ Serenity/JS விருப்பமான ஒருங்கிணைப்பு நூலகங்களையும் வழங்குகிறது!
Serenity/JS ஐ நிறுவுதல்
ஏற்கனவே உள்ள WebdriverIO திட்டத்தில் Serenity/JS சேர்க்க, பின்வரும் Serenity/JS தொகுதிகளை NPM-இலிருந்து நிறுவவும்:
- npm
- Yarn
- pnpm
npm install @serenity-js/{core,web,webdriverio,assertions,console-reporter,serenity-bdd} --save-dev
yarn add @serenity-js/{core,web,webdriverio,assertions,console-reporter,serenity-bdd} --dev
pnpm add @serenity-js/{core,web,webdriverio,assertions,console-reporter,serenity-bdd} --save-dev
Serenity/JS தொகுதிகளைப் பற்றி மேலும் அறிய:
@serenity-js/core
@serenity-js/web
@serenity-js/webdriverio
@serenity-js/assertions
@serenity-js/console-reporter
@serenity-js/serenity-bdd
Serenity/JS ஐ உள்ளமைத்தல்
Serenity/JS உடனான ஒருங்கிணைப்பை இயக்க, WebdriverIO-வை பின்வருமாறு உள்ளமைக்கவும்:
- TypeScript
- JavaScript
import { WebdriverIOConfig } from '@serenity-js/webdriverio';
export const config: WebdriverIOConfig = {
// Tell WebdriverIO to use Serenity/JS framework
framework: '@serenity-js/webdriverio',
// Serenity/JS configuration
serenity: {
// Configure Serenity/JS to use the appropriate adapter for your test runner
runner: 'cucumber',
// runner: 'mocha',
// runner: 'jasmine',
// Register Serenity/JS reporting services, a.k.a. the "stage crew"
crew: [
// Optional, print test execution results to standard output
'@serenity-js/console-reporter',
// Optional, produce Serenity BDD reports and living documentation (HTML)
'@serenity-js/serenity-bdd',
[ '@serenity-js/core:ArtifactArchiver', { outputDirectory: 'target/site/serenity' } ],
// Optional, automatically capture screenshots upon interaction failure
[ '@serenity-js/web:Photographer', { strategy: 'TakePhotosOfFailures' } ],
]
},
// Configure your Cucumber runner
cucumberOpts: {
// see Cucumber configuration options below
},
// ... or Jasmine runner
jasmineOpts: {
// see Jasmine configuration options below
},
// ... or Mocha runner
mochaOpts: {
// see Mocha configuration options below
},
runner: 'local',
// Any other WebdriverIO configuration
};
export const config = {
// Tell WebdriverIO to use Serenity/JS framework
framework: '@serenity-js/webdriverio',
// Serenity/JS configuration
serenity: {
// Configure Serenity/JS to use the appropriate adapter for your test runner
runner: 'cucumber',
// runner: 'mocha',
// runner: 'jasmine',
// Register Serenity/JS reporting services, a.k.a. the "stage crew"
crew: [
'@serenity-js/console-reporter',
'@serenity-js/serenity-bdd',
[ '@serenity-js/core:ArtifactArchiver', { outputDirectory: 'target/site/serenity' } ],
[ '@serenity-js/web:Photographer', { strategy: 'TakePhotosOfFailures' } ],
]
},
// Configure your Cucumber runner
cucumberOpts: {
// see Cucumber configuration options below
},
// ... or Jasmine runner
jasmineOpts: {
// see Jasmine configuration options below
},
// ... or Mocha runner
mochaOpts: {
// see Mocha configuration options below
},
runner: 'local',
// Any other WebdriverIO configuration
};
இவற்றைப் பற்றி மேலும் அறிக:
- Serenity/JS Cucumber உள்ளமைவு விருப்பங்கள்
- Serenity/JS Jasmine உள்ளமைவு விருப்பங்கள்
- Serenity/JS Mocha உள்ளமைவு விருப்பங்கள்
- WebdriverIO உள்ளமைவு கோப்பு
Serenity BDD அறிக்கைகளையும் உயிருள்ள ஆவணங்களையும் உருவாக்குதல்
Serenity BDD அறிக்கைகள் மற்றும் உயிருள்ள ஆவணங்கள் Serenity BDD CLI மூலம் உருவாக்கப்படுகின்றன, இது @serenity-js/serenity-bdd
தொகுதியால் பதிவிறக்கம் செய்யப்பட்டு நிர்வகிக்கப்படும் ஒரு Java நிரல்.
Serenity BDD அறிக்கைகளை உருவாக்க, உங்கள் சோதனை தொகுப்பு செய்ய வேண்டியவை:
- Serenity BDD CLI ஐப் பதிவிறக்கவும்,
serenity-bdd update
என அழைப்பதன் மூலம், இது CLIjar
ஐ உள்ளூரில் தற்காலிகமாக சேமிக்கிறது - இடைநிலை Serenity BDD
.json
அறிக்கைகளை உருவாக்கவும், உள்ளமைவு வழிமுறைகளின்படிSerenityBDDReporter
பதிவு செய்வதன் மூலம் - நீங்கள் அறிக்கையை உருவாக்க விரும்பும்போது, Serenity BDD CLI ஐ அழைக்கவும்,
serenity-bdd run
என அழைப்பதன் மூலம்
அனைத்து Serenity/JS திட்ட Template-களாலும் பயன்படுத்தப்படும் முறை பின்வருவனவற்றைப் பயன்படுத்துவதை சார்ந்துள்ளது:
- Serenity BDD CLI பதிவிறக்க
postinstall
NPM script - சோதனை தொகுப்பு தோல்வியடைந்திருந்தாலும் (நீங்கள் சோதனை அறிக்கைகளை அதிகமாகத் தேவைப்படும் சரியான நேரத்தில்...) அறிக்கையிடும் செயல்முறையை இயக்க
npm-failsafe
- முந்தைய இயக்கத்திலிருந்து மீதமுள்ள எந்த சோதனை அறிக்கைகளையும் நீக்குவதற்கான வசதி முறையாக
rimraf
{
"scripts": {
"postinstall": "serenity-bdd update",
"clean": "rimraf target",
"test": "failsafe clean test:execute test:report",
"test:execute": "wdio wdio.conf.ts",
"test:report": "serenity-bdd run"
}
}
SerenityBDDReporter
பற்றி மேலும் அறிய, தயவுசெய்து இவற்றைப் பார்க்கவும்:
@serenity-js/serenity-bdd
ஆவணங்களில் நிறுவல் வழிமுறைகள்,SerenityBDDReporter
API ஆவணங்களில் உள்ளமைவு உதாரணங்கள்,- GitHub-இல் உள்ள Serenity/JS உதாரணங்கள்.
Serenity/JS Screenplay Pattern APIs பயன்படுத்துதல்
Screenplay Pattern என்பது உயர் தரமான தானியங்கி ஏற்பு சோதனைகளை எழுதுவதற்கான ஒரு புதுமையான, பயனர் மையமான அணுகுமுறையாகும். இது அடுக்குகளை திறம்பட பயன்படுத்துவதற்கு உங்களை வழிநடத்துகிறது, உங்கள் சோதனை சிக்கல்கள் உங்கள் டொமைனின் வணிக வார்த்தையாடலைக் கைப்பற்ற உதவுகிறது, மேலும் உங்கள் குழுவில் நல்ல சோதனை மற்றும் மென்பொருள் பொறியியல் பழக்கங்களை ஊக்குவிக்கிறது.
இயல்பாக, @serenity-js/webdriverio
-ஐ உங்கள் WebdriverIO framework
-ஆக பதிவு செய்யும்போது, Serenity/JS ஒரு இயல்புநிலை cast of actors உள்ளமைக்கப்படும், இதில் ஒவ்வொரு நடிகரும் செய்யக்கூடியவை:
இது ஏற்கனவே உள்ள சோதனை தொகுப்புக்கும் கூட Screenplay Pattern பின்பற்றும் சோதனை சிக்கல்களை அறிமுகப்படுத்துவதற்கு உங்களுக்கு உதவ போதுமானதாக இருக்க வேண்டும், எடுத்துக்காட்டாக:
import { actorCalled } from '@serenity-js/core'
import { Navigate, Page } from '@serenity-js/web'
import { Ensure, equals } from '@serenity-js/assertions'
describe('My awesome website', () => {
it('can have test scenarios that follow the Screenplay Pattern', async () => {
await actorCalled('Alice').attemptsTo(
Navigate.to(`https://webdriver.io`),
Ensure.that(
Page.current().title(),
equals(`WebdriverIO · Next-gen browser and mobile automation test framework for Node.js | WebdriverIO`)
),
)
})
it('can have non-Screenplay scenarios too', async () => {
await browser.url('https://webdriver.io')
await expect(browser)
.toHaveTitle('WebdriverIO · Next-gen browser and mobile automation test framework for Node.js | WebdriverIO')
})
})
Screenplay Pattern பற்றி மேலும் அறிய, இவற்றைப் பார்க்கவும்: