codeceptjs 3.5.0 → 3.5.1-2.beta.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +24 -25
- package/lib/actor.js +6 -3
- package/lib/ai.js +12 -3
- package/lib/cli.js +12 -2
- package/lib/codecept.js +4 -0
- package/lib/colorUtils.js +10 -0
- package/lib/command/definitions.js +2 -7
- package/lib/command/dryRun.js +2 -1
- package/lib/command/info.js +24 -0
- package/lib/command/init.js +51 -5
- package/lib/command/run-multiple/collection.js +17 -5
- package/lib/command/run-multiple.js +4 -2
- package/lib/command/run-workers.js +66 -4
- package/lib/command/run.js +7 -0
- package/lib/command/workers/runTests.js +39 -0
- package/lib/data/context.js +14 -6
- package/lib/event.js +4 -0
- package/lib/helper/ApiDataFactory.js +2 -1
- package/lib/helper/Appium.js +73 -24
- package/lib/helper/Expect.js +422 -0
- package/lib/helper/FileSystem.js +1 -1
- package/lib/helper/GraphQL.js +25 -0
- package/lib/helper/Nightmare.js +9 -4
- package/lib/helper/OpenAI.js +14 -10
- package/lib/helper/Playwright.js +1205 -288
- package/lib/helper/Protractor.js +11 -6
- package/lib/helper/Puppeteer.js +173 -61
- package/lib/helper/TestCafe.js +44 -9
- package/lib/helper/WebDriver.js +231 -82
- package/lib/helper/errors/ElementNotFound.js +2 -1
- package/lib/helper/extras/PlaywrightReactVueLocator.js +38 -0
- package/lib/helper/scripts/blurElement.js +17 -0
- package/lib/helper/scripts/focusElement.js +17 -0
- package/lib/helper/scripts/highlightElement.js +2 -2
- package/lib/html.js +3 -3
- package/lib/interfaces/bdd.js +1 -1
- package/lib/interfaces/gherkin.js +37 -3
- package/lib/interfaces/scenarioConfig.js +1 -0
- package/lib/locator.js +17 -4
- package/lib/mochaFactory.js +2 -1
- package/lib/output.js +1 -1
- package/lib/pause.js +12 -9
- package/lib/plugin/autoLogin.js +45 -10
- package/lib/plugin/heal.js +47 -17
- package/lib/plugin/retryFailedStep.js +10 -1
- package/lib/plugin/retryTo.js +2 -4
- package/lib/plugin/selenoid.js +6 -1
- package/lib/plugin/standardActingHelpers.js +0 -2
- package/lib/plugin/stepByStepReport.js +2 -2
- package/lib/plugin/tryTo.js +5 -7
- package/lib/plugin/wdio.js +0 -1
- package/lib/recorder.js +20 -9
- package/lib/session.js +1 -1
- package/lib/step.js +30 -11
- package/lib/ui.js +1 -0
- package/lib/utils.js +18 -1
- package/lib/workers.js +28 -3
- package/package.json +108 -98
- package/translations/de-DE.js +5 -0
- package/translations/fr-FR.js +14 -1
- package/translations/it-IT.js +1 -0
- package/translations/ja-JP.js +5 -0
- package/translations/pl-PL.js +5 -0
- package/translations/pt-BR.js +1 -0
- package/translations/ru-RU.js +1 -0
- package/translations/zh-CN.js +5 -0
- package/translations/zh-TW.js +5 -0
- package/typings/index.d.ts +8 -6
- package/typings/promiseBasedTypes.d.ts +784 -822
- package/typings/types.d.ts +1214 -727
- package/CHANGELOG.md +0 -2492
- package/docs/advanced.md +0 -351
- package/docs/ai.md +0 -246
- package/docs/api.md +0 -323
- package/docs/basics.md +0 -980
- package/docs/bdd.md +0 -535
- package/docs/best.md +0 -237
- package/docs/books.md +0 -37
- package/docs/bootstrap.md +0 -135
- package/docs/build/ApiDataFactory.js +0 -409
- package/docs/build/Appium.js +0 -1978
- package/docs/build/FileSystem.js +0 -228
- package/docs/build/GraphQL.js +0 -204
- package/docs/build/GraphQLDataFactory.js +0 -309
- package/docs/build/JSONResponse.js +0 -338
- package/docs/build/Mochawesome.js +0 -71
- package/docs/build/Nightmare.js +0 -2147
- package/docs/build/OpenAI.js +0 -122
- package/docs/build/Playwright.js +0 -4134
- package/docs/build/Polly.js +0 -42
- package/docs/build/Protractor.js +0 -2701
- package/docs/build/Puppeteer.js +0 -3743
- package/docs/build/REST.js +0 -344
- package/docs/build/SeleniumWebdriver.js +0 -76
- package/docs/build/TestCafe.js +0 -2059
- package/docs/build/WebDriver.js +0 -4042
- package/docs/changelog.md +0 -2501
- package/docs/commands.md +0 -254
- package/docs/community-helpers.md +0 -58
- package/docs/configuration.md +0 -157
- package/docs/continuous-integration.md +0 -22
- package/docs/custom-helpers.md +0 -306
- package/docs/data.md +0 -375
- package/docs/detox.md +0 -235
- package/docs/docker.md +0 -137
- package/docs/email.md +0 -183
- package/docs/examples.md +0 -149
- package/docs/helpers/ApiDataFactory.md +0 -266
- package/docs/helpers/Appium.md +0 -1317
- package/docs/helpers/Detox.md +0 -586
- package/docs/helpers/FileSystem.md +0 -152
- package/docs/helpers/GraphQL.md +0 -130
- package/docs/helpers/GraphQLDataFactory.md +0 -226
- package/docs/helpers/JSONResponse.md +0 -254
- package/docs/helpers/Mochawesome.md +0 -8
- package/docs/helpers/MockRequest.md +0 -377
- package/docs/helpers/Nightmare.md +0 -1258
- package/docs/helpers/OpenAI.md +0 -70
- package/docs/helpers/Playwright.md +0 -2250
- package/docs/helpers/Polly.md +0 -44
- package/docs/helpers/Puppeteer-firefox.md +0 -86
- package/docs/helpers/Puppeteer.md +0 -2147
- package/docs/helpers/REST.md +0 -218
- package/docs/helpers/TestCafe.md +0 -1224
- package/docs/helpers/WebDriver.md +0 -2325
- package/docs/hooks.md +0 -340
- package/docs/index.md +0 -111
- package/docs/installation.md +0 -75
- package/docs/internal-api.md +0 -265
- package/docs/locators.md +0 -331
- package/docs/mobile-react-native-locators.md +0 -67
- package/docs/mobile.md +0 -344
- package/docs/nightmare.md +0 -223
- package/docs/pageobjects.md +0 -291
- package/docs/parallel.md +0 -288
- package/docs/playwright.md +0 -609
- package/docs/plugins.md +0 -1225
- package/docs/puppeteer.md +0 -316
- package/docs/quickstart.md +0 -163
- package/docs/react.md +0 -69
- package/docs/reports.md +0 -392
- package/docs/secrets.md +0 -36
- package/docs/shadow.md +0 -68
- package/docs/shared/keys.mustache +0 -31
- package/docs/shared/react.mustache +0 -1
- package/docs/testcafe.md +0 -174
- package/docs/translation.md +0 -247
- package/docs/tutorial.md +0 -271
- package/docs/typescript.md +0 -180
- package/docs/ui.md +0 -59
- package/docs/videos.md +0 -28
- package/docs/visual.md +0 -202
- package/docs/vue.md +0 -121
- package/docs/webapi/amOnPage.mustache +0 -11
- package/docs/webapi/appendField.mustache +0 -11
- package/docs/webapi/attachFile.mustache +0 -12
- package/docs/webapi/checkOption.mustache +0 -13
- package/docs/webapi/clearCookie.mustache +0 -10
- package/docs/webapi/clearField.mustache +0 -9
- package/docs/webapi/click.mustache +0 -25
- package/docs/webapi/clickLink.mustache +0 -8
- package/docs/webapi/closeCurrentTab.mustache +0 -7
- package/docs/webapi/closeOtherTabs.mustache +0 -8
- package/docs/webapi/dontSee.mustache +0 -11
- package/docs/webapi/dontSeeCheckboxIsChecked.mustache +0 -10
- package/docs/webapi/dontSeeCookie.mustache +0 -8
- package/docs/webapi/dontSeeCurrentUrlEquals.mustache +0 -10
- package/docs/webapi/dontSeeElement.mustache +0 -8
- package/docs/webapi/dontSeeElementInDOM.mustache +0 -8
- package/docs/webapi/dontSeeInCurrentUrl.mustache +0 -4
- package/docs/webapi/dontSeeInField.mustache +0 -11
- package/docs/webapi/dontSeeInSource.mustache +0 -8
- package/docs/webapi/dontSeeInTitle.mustache +0 -8
- package/docs/webapi/doubleClick.mustache +0 -13
- package/docs/webapi/downloadFile.mustache +0 -12
- package/docs/webapi/dragAndDrop.mustache +0 -9
- package/docs/webapi/dragSlider.mustache +0 -11
- package/docs/webapi/executeAsyncScript.mustache +0 -24
- package/docs/webapi/executeScript.mustache +0 -26
- package/docs/webapi/fillField.mustache +0 -16
- package/docs/webapi/forceClick.mustache +0 -28
- package/docs/webapi/forceRightClick.mustache +0 -18
- package/docs/webapi/grabAllWindowHandles.mustache +0 -7
- package/docs/webapi/grabAttributeFrom.mustache +0 -10
- package/docs/webapi/grabAttributeFromAll.mustache +0 -9
- package/docs/webapi/grabBrowserLogs.mustache +0 -9
- package/docs/webapi/grabCookie.mustache +0 -11
- package/docs/webapi/grabCssPropertyFrom.mustache +0 -11
- package/docs/webapi/grabCssPropertyFromAll.mustache +0 -10
- package/docs/webapi/grabCurrentUrl.mustache +0 -9
- package/docs/webapi/grabCurrentWindowHandle.mustache +0 -6
- package/docs/webapi/grabDataFromPerformanceTiming.mustache +0 -20
- package/docs/webapi/grabElementBoundingRect.mustache +0 -20
- package/docs/webapi/grabGeoLocation.mustache +0 -8
- package/docs/webapi/grabHTMLFrom.mustache +0 -10
- package/docs/webapi/grabHTMLFromAll.mustache +0 -9
- package/docs/webapi/grabNumberOfOpenTabs.mustache +0 -8
- package/docs/webapi/grabNumberOfVisibleElements.mustache +0 -9
- package/docs/webapi/grabPageScrollPosition.mustache +0 -8
- package/docs/webapi/grabPopupText.mustache +0 -5
- package/docs/webapi/grabSource.mustache +0 -8
- package/docs/webapi/grabTextFrom.mustache +0 -10
- package/docs/webapi/grabTextFromAll.mustache +0 -9
- package/docs/webapi/grabTitle.mustache +0 -8
- package/docs/webapi/grabValueFrom.mustache +0 -9
- package/docs/webapi/grabValueFromAll.mustache +0 -8
- package/docs/webapi/moveCursorTo.mustache +0 -12
- package/docs/webapi/openNewTab.mustache +0 -7
- package/docs/webapi/pressKey.mustache +0 -12
- package/docs/webapi/pressKeyDown.mustache +0 -12
- package/docs/webapi/pressKeyUp.mustache +0 -12
- package/docs/webapi/pressKeyWithKeyNormalization.mustache +0 -60
- package/docs/webapi/refreshPage.mustache +0 -6
- package/docs/webapi/resizeWindow.mustache +0 -6
- package/docs/webapi/rightClick.mustache +0 -14
- package/docs/webapi/saveElementScreenshot.mustache +0 -10
- package/docs/webapi/saveScreenshot.mustache +0 -12
- package/docs/webapi/say.mustache +0 -10
- package/docs/webapi/scrollIntoView.mustache +0 -11
- package/docs/webapi/scrollPageToBottom.mustache +0 -6
- package/docs/webapi/scrollPageToTop.mustache +0 -6
- package/docs/webapi/scrollTo.mustache +0 -12
- package/docs/webapi/see.mustache +0 -11
- package/docs/webapi/seeAttributesOnElements.mustache +0 -9
- package/docs/webapi/seeCheckboxIsChecked.mustache +0 -10
- package/docs/webapi/seeCookie.mustache +0 -8
- package/docs/webapi/seeCssPropertiesOnElements.mustache +0 -9
- package/docs/webapi/seeCurrentUrlEquals.mustache +0 -11
- package/docs/webapi/seeElement.mustache +0 -8
- package/docs/webapi/seeElementInDOM.mustache +0 -8
- package/docs/webapi/seeInCurrentUrl.mustache +0 -8
- package/docs/webapi/seeInField.mustache +0 -12
- package/docs/webapi/seeInPopup.mustache +0 -8
- package/docs/webapi/seeInSource.mustache +0 -7
- package/docs/webapi/seeInTitle.mustache +0 -8
- package/docs/webapi/seeNumberOfElements.mustache +0 -11
- package/docs/webapi/seeNumberOfVisibleElements.mustache +0 -10
- package/docs/webapi/seeTextEquals.mustache +0 -9
- package/docs/webapi/seeTitleEquals.mustache +0 -8
- package/docs/webapi/selectOption.mustache +0 -21
- package/docs/webapi/setCookie.mustache +0 -16
- package/docs/webapi/setGeoLocation.mustache +0 -12
- package/docs/webapi/switchTo.mustache +0 -9
- package/docs/webapi/switchToNextTab.mustache +0 -10
- package/docs/webapi/switchToPreviousTab.mustache +0 -10
- package/docs/webapi/type.mustache +0 -21
- package/docs/webapi/uncheckOption.mustache +0 -13
- package/docs/webapi/wait.mustache +0 -8
- package/docs/webapi/waitForClickable.mustache +0 -11
- package/docs/webapi/waitForDetached.mustache +0 -10
- package/docs/webapi/waitForElement.mustache +0 -11
- package/docs/webapi/waitForEnabled.mustache +0 -6
- package/docs/webapi/waitForFunction.mustache +0 -17
- package/docs/webapi/waitForInvisible.mustache +0 -10
- package/docs/webapi/waitForText.mustache +0 -13
- package/docs/webapi/waitForValue.mustache +0 -10
- package/docs/webapi/waitForVisible.mustache +0 -10
- package/docs/webapi/waitInUrl.mustache +0 -9
- package/docs/webapi/waitNumberOfVisibleElements.mustache +0 -10
- package/docs/webapi/waitToHide.mustache +0 -10
- package/docs/webapi/waitUrlEquals.mustache +0 -10
- package/docs/webdriver.md +0 -657
- package/docs/wiki/Books-&-Posts.md +0 -27
- package/docs/wiki/Community-Helpers-&-Plugins.md +0 -49
- package/docs/wiki/Converting-Playwright-to-Istanbul-Coverage.md +0 -29
- package/docs/wiki/Examples.md +0 -139
- package/docs/wiki/Google-Summer-of-Code-(GSoC)-2020.md +0 -68
- package/docs/wiki/Home.md +0 -16
- package/docs/wiki/Release-Process.md +0 -24
- package/docs/wiki/Roadmap.md +0 -23
- package/docs/wiki/Tests.md +0 -1393
- package/docs/wiki/Upgrading-to-CodeceptJS-3.md +0 -153
- package/docs/wiki/Videos.md +0 -19
|
@@ -1,254 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
permalink: /helpers/JSONResponse
|
|
3
|
-
editLink: false
|
|
4
|
-
sidebar: auto
|
|
5
|
-
title: JSONResponse
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
<!-- Generated by documentation.js. Update this documentation by updating the source code. -->
|
|
9
|
-
|
|
10
|
-
## JSONResponse
|
|
11
|
-
|
|
12
|
-
**Extends Helper**
|
|
13
|
-
|
|
14
|
-
This helper allows performing assertions on JSON responses paired with following helpers:
|
|
15
|
-
|
|
16
|
-
- REST
|
|
17
|
-
- GraphQL
|
|
18
|
-
- Playwright
|
|
19
|
-
|
|
20
|
-
It can check status codes, response data, response structure.
|
|
21
|
-
|
|
22
|
-
## Configuration
|
|
23
|
-
|
|
24
|
-
- `requestHelper` - a helper which will perform requests. `REST` by default, also `Playwright` or `GraphQL` can be used. Custom helpers must have `onResponse` hook in their config, which will be executed when request is performed.
|
|
25
|
-
|
|
26
|
-
### Examples
|
|
27
|
-
|
|
28
|
-
Zero-configuration when paired with REST:
|
|
29
|
-
|
|
30
|
-
```js
|
|
31
|
-
// inside codecept.conf.js
|
|
32
|
-
{
|
|
33
|
-
helpers: {
|
|
34
|
-
REST: {
|
|
35
|
-
endpoint: 'http://site.com/api',
|
|
36
|
-
},
|
|
37
|
-
JSONResponse: {}
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
```
|
|
41
|
-
|
|
42
|
-
Explicitly setting request helper if you use `makeApiRequest` of Playwright to perform requests and not paired REST:
|
|
43
|
-
|
|
44
|
-
```js
|
|
45
|
-
// inside codecept.conf.js
|
|
46
|
-
// ...
|
|
47
|
-
helpers: {
|
|
48
|
-
Playwright: {
|
|
49
|
-
url: 'https://localhost',
|
|
50
|
-
browser: 'chromium',
|
|
51
|
-
},
|
|
52
|
-
JSONResponse: {
|
|
53
|
-
requestHelper: 'Playwright',
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
```
|
|
57
|
-
|
|
58
|
-
## Access From Helpers
|
|
59
|
-
|
|
60
|
-
If you plan to add custom assertions it is recommended to create a helper that will retrieve response object from JSONResponse:
|
|
61
|
-
|
|
62
|
-
```js
|
|
63
|
-
// inside custom helper
|
|
64
|
-
const response = this.helpers.JSONResponse.response;
|
|
65
|
-
```
|
|
66
|
-
|
|
67
|
-
## Methods
|
|
68
|
-
|
|
69
|
-
### Parameters
|
|
70
|
-
|
|
71
|
-
- `config`
|
|
72
|
-
|
|
73
|
-
### dontSeeResponseCodeIs
|
|
74
|
-
|
|
75
|
-
Checks that response code is not equal to the provided one
|
|
76
|
-
|
|
77
|
-
```js
|
|
78
|
-
I.dontSeeResponseCodeIs(500);
|
|
79
|
-
```
|
|
80
|
-
|
|
81
|
-
#### Parameters
|
|
82
|
-
|
|
83
|
-
- `code` **[number][1]**
|
|
84
|
-
|
|
85
|
-
### dontSeeResponseContainsJson
|
|
86
|
-
|
|
87
|
-
Checks for deep inclusion of a provided json in a response data.
|
|
88
|
-
|
|
89
|
-
```js
|
|
90
|
-
// response.data == { data: { user: 1 } }
|
|
91
|
-
|
|
92
|
-
I.dontSeeResponseContainsJson({ user: 2 });
|
|
93
|
-
```
|
|
94
|
-
|
|
95
|
-
If an array is received, checks that no element of array contains json:
|
|
96
|
-
|
|
97
|
-
```js
|
|
98
|
-
// response.data == [{ user: 1 }, { user: 3 }]
|
|
99
|
-
|
|
100
|
-
I.dontSeeResponseContainsJson({ user: 2 });
|
|
101
|
-
```
|
|
102
|
-
|
|
103
|
-
#### Parameters
|
|
104
|
-
|
|
105
|
-
- `json` **[object][2]**
|
|
106
|
-
|
|
107
|
-
### seeResponseCodeIs
|
|
108
|
-
|
|
109
|
-
Checks that response code is equal to the provided one
|
|
110
|
-
|
|
111
|
-
```js
|
|
112
|
-
I.seeResponseCodeIs(200);
|
|
113
|
-
```
|
|
114
|
-
|
|
115
|
-
#### Parameters
|
|
116
|
-
|
|
117
|
-
- `code` **[number][1]**
|
|
118
|
-
|
|
119
|
-
### seeResponseCodeIsClientError
|
|
120
|
-
|
|
121
|
-
Checks that the response code is 4xx
|
|
122
|
-
|
|
123
|
-
### seeResponseCodeIsRedirection
|
|
124
|
-
|
|
125
|
-
Checks that the response code is 3xx
|
|
126
|
-
|
|
127
|
-
### seeResponseCodeIsServerError
|
|
128
|
-
|
|
129
|
-
Checks that the response code is 5xx
|
|
130
|
-
|
|
131
|
-
### seeResponseCodeIsSuccessful
|
|
132
|
-
|
|
133
|
-
Checks that the response code is 2xx
|
|
134
|
-
Use it instead of seeResponseCodeIs(200) if server can return 204 instead.
|
|
135
|
-
|
|
136
|
-
```js
|
|
137
|
-
I.seeResponseCodeIsSuccessful();
|
|
138
|
-
```
|
|
139
|
-
|
|
140
|
-
### seeResponseContainsJson
|
|
141
|
-
|
|
142
|
-
Checks for deep inclusion of a provided json in a response data.
|
|
143
|
-
|
|
144
|
-
```js
|
|
145
|
-
// response.data == { user: { name: 'jon', email: 'jon@doe.com' } }
|
|
146
|
-
|
|
147
|
-
I.seeResponseContainsJson({ user: { email: 'jon@doe.com' } });
|
|
148
|
-
```
|
|
149
|
-
|
|
150
|
-
If an array is received, checks that at least one element contains JSON
|
|
151
|
-
|
|
152
|
-
```js
|
|
153
|
-
// response.data == [{ user: { name: 'jon', email: 'jon@doe.com' } }]
|
|
154
|
-
|
|
155
|
-
I.seeResponseContainsJson({ user: { email: 'jon@doe.com' } });
|
|
156
|
-
```
|
|
157
|
-
|
|
158
|
-
#### Parameters
|
|
159
|
-
|
|
160
|
-
- `json` **[object][2]**
|
|
161
|
-
|
|
162
|
-
### seeResponseContainsKeys
|
|
163
|
-
|
|
164
|
-
Checks for deep inclusion of a provided json in a response data.
|
|
165
|
-
|
|
166
|
-
```js
|
|
167
|
-
// response.data == { user: { name: 'jon', email: 'jon@doe.com' } }
|
|
168
|
-
|
|
169
|
-
I.seeResponseContainsKeys(['user']);
|
|
170
|
-
```
|
|
171
|
-
|
|
172
|
-
If an array is received, check is performed for each element of array:
|
|
173
|
-
|
|
174
|
-
```js
|
|
175
|
-
// response.data == [{ user: 'jon' }, { user: 'matt'}]
|
|
176
|
-
|
|
177
|
-
I.seeResponseContainsKeys(['user']);
|
|
178
|
-
```
|
|
179
|
-
|
|
180
|
-
#### Parameters
|
|
181
|
-
|
|
182
|
-
- `keys` **[array][3]**
|
|
183
|
-
|
|
184
|
-
### seeResponseEquals
|
|
185
|
-
|
|
186
|
-
Checks that response data equals to expected:
|
|
187
|
-
|
|
188
|
-
```js
|
|
189
|
-
// response.data is { error: 'Not allowed' }
|
|
190
|
-
|
|
191
|
-
I.seeResponseEquals({ error: 'Not allowed' })
|
|
192
|
-
```
|
|
193
|
-
|
|
194
|
-
#### Parameters
|
|
195
|
-
|
|
196
|
-
- `resp` **[object][2]**
|
|
197
|
-
|
|
198
|
-
### seeResponseMatchesJsonSchema
|
|
199
|
-
|
|
200
|
-
Validates JSON structure of response using [joi library][4].
|
|
201
|
-
See [joi API][5] for complete reference on usage.
|
|
202
|
-
|
|
203
|
-
Use pre-initialized joi instance by passing function callback:
|
|
204
|
-
|
|
205
|
-
```js
|
|
206
|
-
// response.data is { name: 'jon', id: 1 }
|
|
207
|
-
|
|
208
|
-
I.seeResponseMatchesJsonSchema(joi => {
|
|
209
|
-
return joi.object({
|
|
210
|
-
name: joi.string(),
|
|
211
|
-
id: joi.number()
|
|
212
|
-
})
|
|
213
|
-
});
|
|
214
|
-
|
|
215
|
-
// or pass a valid schema
|
|
216
|
-
const joi = require('joi');
|
|
217
|
-
|
|
218
|
-
I.seeResponseMatchesJsonSchema(joi.object({
|
|
219
|
-
name: joi.string(),
|
|
220
|
-
id: joi.number();
|
|
221
|
-
});
|
|
222
|
-
```
|
|
223
|
-
|
|
224
|
-
#### Parameters
|
|
225
|
-
|
|
226
|
-
- `fnOrSchema` **any**
|
|
227
|
-
|
|
228
|
-
### seeResponseValidByCallback
|
|
229
|
-
|
|
230
|
-
Executes a callback function passing in `response` object and chai assertions with `expect`
|
|
231
|
-
Use it to perform custom checks of response data
|
|
232
|
-
|
|
233
|
-
```js
|
|
234
|
-
I.seeResponseValidByCallback(({ data, status, expect }) => {
|
|
235
|
-
expect(status).to.eql(200);
|
|
236
|
-
expect(data).keys.to.include(['user', 'company']);
|
|
237
|
-
});
|
|
238
|
-
```
|
|
239
|
-
|
|
240
|
-
#### Parameters
|
|
241
|
-
|
|
242
|
-
- `fn` **[function][6]**
|
|
243
|
-
|
|
244
|
-
[1]: https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number
|
|
245
|
-
|
|
246
|
-
[2]: https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object
|
|
247
|
-
|
|
248
|
-
[3]: https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array
|
|
249
|
-
|
|
250
|
-
[4]: https://joi.dev
|
|
251
|
-
|
|
252
|
-
[5]: https://joi.dev/api/
|
|
253
|
-
|
|
254
|
-
[6]: https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function
|
|
@@ -1,377 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
permalink: /helpers/MockRequest
|
|
3
|
-
sidebar: auto
|
|
4
|
-
title: MockRequest
|
|
5
|
-
---
|
|
6
|
-
|
|
7
|
-
# MockRequest
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
<!-- Generated by documentation.js. Update this documentation by updating the source code. -->
|
|
11
|
-
|
|
12
|
-
## MockRequest
|
|
13
|
-
|
|
14
|
-
This helper allows to **mock requests while running tests in Puppeteer or WebDriver**.
|
|
15
|
-
For instance, you can block calls to 3rd-party services like Google Analytics, CDNs.
|
|
16
|
-
Another way of using is to emulate requests from server by passing prepared data.
|
|
17
|
-
|
|
18
|
-
MockRequest helper works in these [modes][1]:
|
|
19
|
-
|
|
20
|
-
- passthrough (default) - mock prefefined HTTP requests
|
|
21
|
-
- record - record all requests into a file
|
|
22
|
-
- replay - replay all recorded requests from a file
|
|
23
|
-
|
|
24
|
-
Combining record/replay modes allows testing websites with large datasets.
|
|
25
|
-
|
|
26
|
-
To use in passthrough mode set rules to mock requests and they will be automatically intercepted and replaced:
|
|
27
|
-
|
|
28
|
-
```js
|
|
29
|
-
// default mode
|
|
30
|
-
I.mockRequest('GET', '/api/users', '[]');
|
|
31
|
-
```
|
|
32
|
-
|
|
33
|
-
In record-replay mode start mocking to make HTTP requests recorded/replayed, and stop when you don't need to block requests anymore:
|
|
34
|
-
|
|
35
|
-
```js
|
|
36
|
-
// record or replay all XHR for /users page
|
|
37
|
-
I.startMocking();
|
|
38
|
-
I.amOnPage('/users');
|
|
39
|
-
I.stopMocking();
|
|
40
|
-
```
|
|
41
|
-
|
|
42
|
-
### Installations
|
|
43
|
-
|
|
44
|
-
npm i @codeceptjs/mock-request --save-dev
|
|
45
|
-
|
|
46
|
-
Requires Puppeteer helper or WebDriver helper enabled
|
|
47
|
-
|
|
48
|
-
### Configuration
|
|
49
|
-
|
|
50
|
-
#### With Puppeteer
|
|
51
|
-
|
|
52
|
-
Enable helper in config file:
|
|
53
|
-
|
|
54
|
-
```js
|
|
55
|
-
helpers: {
|
|
56
|
-
Puppeteer: {
|
|
57
|
-
// regular Puppeteer config here
|
|
58
|
-
},
|
|
59
|
-
MockRequestHelper: {
|
|
60
|
-
require: '@codeceptjs/mock-request',
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
```
|
|
64
|
-
|
|
65
|
-
[Polly config options][2] can be passed as well:
|
|
66
|
-
|
|
67
|
-
```js
|
|
68
|
-
// sample options
|
|
69
|
-
helpers: {
|
|
70
|
-
MockRequestHelper: {
|
|
71
|
-
require: '@codeceptjs/mock-request',
|
|
72
|
-
mode: record,
|
|
73
|
-
recordIfMissing: true,
|
|
74
|
-
recordFailedRequests: false,
|
|
75
|
-
expiresIn: null,
|
|
76
|
-
persisterOptions: {
|
|
77
|
-
keepUnusedRequests: false
|
|
78
|
-
fs: {
|
|
79
|
-
recordingsDir: './data/requests',
|
|
80
|
-
},
|
|
81
|
-
},
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
```
|
|
85
|
-
|
|
86
|
-
* * *
|
|
87
|
-
|
|
88
|
-
**TROUBLESHOOTING**: Puppeteer does not mock requests in headless mode:
|
|
89
|
-
|
|
90
|
-
Problem: request mocking does not work and in debug mode you see this in output:
|
|
91
|
-
|
|
92
|
-
Access to fetch at {url} from origin {url} has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource. If an opaque response serves your needs, set the request's mode to 'no-cors' to fetch the resource with CORS disabled.
|
|
93
|
-
|
|
94
|
-
Solution: update Puppeteer config to include `--disable-web-security` arguments:
|
|
95
|
-
|
|
96
|
-
```js
|
|
97
|
-
Puppeteer: {
|
|
98
|
-
show: false,
|
|
99
|
-
chrome: {
|
|
100
|
-
args: [
|
|
101
|
-
'--disable-web-security',
|
|
102
|
-
],
|
|
103
|
-
},
|
|
104
|
-
},
|
|
105
|
-
```
|
|
106
|
-
|
|
107
|
-
* * *
|
|
108
|
-
|
|
109
|
-
#### With WebDriver
|
|
110
|
-
|
|
111
|
-
This helper partially works with WebDriver. It can intercept and mock requests **only on already loaded page**.
|
|
112
|
-
|
|
113
|
-
```js
|
|
114
|
-
helpers: {
|
|
115
|
-
WebDriver: {
|
|
116
|
-
// regular WebDriver config here
|
|
117
|
-
},
|
|
118
|
-
MockRequestHelper: {
|
|
119
|
-
require: '@codeceptjs/mock-request',
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
```
|
|
123
|
-
|
|
124
|
-
> Record/Replay mode is not tested in WebDriver but technically can work with [REST Persister][3]
|
|
125
|
-
|
|
126
|
-
## Usage
|
|
127
|
-
|
|
128
|
-
### 👻 Mock Requests
|
|
129
|
-
|
|
130
|
-
To intercept API requests and mock them use following API
|
|
131
|
-
|
|
132
|
-
- [startMocking()][4] - to enable request interception
|
|
133
|
-
- [mockRequest()][5] - to define mock in a simple way
|
|
134
|
-
- [mockServer()][6] - to use PollyJS server API to define complex mocks
|
|
135
|
-
- [stopMocking()][7] - to stop intercepting requests and disable mocks.
|
|
136
|
-
|
|
137
|
-
Calling `mockRequest` or `mockServer` will start mocking, if it was not enabled yet.
|
|
138
|
-
|
|
139
|
-
```js
|
|
140
|
-
I.startMocking(); // optionally
|
|
141
|
-
I.mockRequest('/google-analytics/*path', 200);
|
|
142
|
-
// return an empty successful response
|
|
143
|
-
I.mockRequest('GET', '/api/users', 200);
|
|
144
|
-
// mock users api
|
|
145
|
-
I.mockServer(server => {
|
|
146
|
-
server.get('https://server.com/api/users*').
|
|
147
|
-
intercept((req, res) => { res.status(200).json(users);
|
|
148
|
-
});
|
|
149
|
-
});
|
|
150
|
-
I.click('Get users);
|
|
151
|
-
I.stopMocking();
|
|
152
|
-
```
|
|
153
|
-
|
|
154
|
-
### 📼 Record & Replay
|
|
155
|
-
|
|
156
|
-
> At this moment works only with Puppeteer
|
|
157
|
-
|
|
158
|
-
Record & Replay mode allows you to record all xhr & fetch requests and save them to file.
|
|
159
|
-
On next runs those requests can be replayed.
|
|
160
|
-
By default, it stores all passed requests, but this behavior can be customized with `I.mockServer`
|
|
161
|
-
|
|
162
|
-
Set mode via enironment variable, `replay` mode by default:
|
|
163
|
-
|
|
164
|
-
```js
|
|
165
|
-
// enable replay mode
|
|
166
|
-
helpers: {
|
|
167
|
-
Puppeteer: {
|
|
168
|
-
// regular Puppeteer config here
|
|
169
|
-
},
|
|
170
|
-
MockRequest: {
|
|
171
|
-
require: '@codeceptjs/mock-request',
|
|
172
|
-
mode: process.env.MOCK_MODE || 'replay',
|
|
173
|
-
},
|
|
174
|
-
}
|
|
175
|
-
```
|
|
176
|
-
|
|
177
|
-
Interactions between `I.startMocking()` and `I.stopMocking()` will be recorded and saved to `data/requests` directory.
|
|
178
|
-
|
|
179
|
-
```js
|
|
180
|
-
I.startMocking() // record requests under 'Test' name
|
|
181
|
-
I.startMocking('users') // record requests under 'users' name
|
|
182
|
-
```
|
|
183
|
-
|
|
184
|
-
Use `I.mockServer()` to customize which requests should be recorded and under which name:
|
|
185
|
-
|
|
186
|
-
```js
|
|
187
|
-
I.startMocking();
|
|
188
|
-
I.mockServer((server) => {
|
|
189
|
-
// mock request only from ap1.com and api2.com and
|
|
190
|
-
// store recording into two different files
|
|
191
|
-
server.any('https://api1.com/*').passthrough(false).recordingName('api1');
|
|
192
|
-
server.any('https://api2.com/*').passthrough(false).recordingName('api2');
|
|
193
|
-
});
|
|
194
|
-
```
|
|
195
|
-
|
|
196
|
-
To stop request recording/replaying use `I.stopMocking()`.
|
|
197
|
-
|
|
198
|
-
🎥 To record HTTP interactions execute tests with MOCK_MODE environment variable set as "record":
|
|
199
|
-
|
|
200
|
-
MOCK_MODE=record npx codeceptjs run --debug
|
|
201
|
-
|
|
202
|
-
📼 To replay them launch tests without environment variable:
|
|
203
|
-
|
|
204
|
-
npx codeceptjs run --debug
|
|
205
|
-
|
|
206
|
-
### Parameters
|
|
207
|
-
|
|
208
|
-
- `config`
|
|
209
|
-
|
|
210
|
-
### flushMocking
|
|
211
|
-
|
|
212
|
-
Waits for all requests handled by MockRequests to be resolved:
|
|
213
|
-
|
|
214
|
-
```js
|
|
215
|
-
I.flushMocking();
|
|
216
|
-
```
|
|
217
|
-
|
|
218
|
-
### mockRequest
|
|
219
|
-
|
|
220
|
-
Mock response status
|
|
221
|
-
|
|
222
|
-
```js
|
|
223
|
-
I.mockRequest('GET', '/api/users', 200);
|
|
224
|
-
I.mockRequest('ANY', '/secretsRoutes/*', 403);
|
|
225
|
-
I.mockRequest('POST', '/secrets', { secrets: 'fakeSecrets' });
|
|
226
|
-
I.mockRequest('GET', '/api/users/1', 404, 'User not found');
|
|
227
|
-
```
|
|
228
|
-
|
|
229
|
-
Multiple requests
|
|
230
|
-
|
|
231
|
-
```js
|
|
232
|
-
I.mockRequest('GET', ['/secrets', '/v2/secrets'], 403);
|
|
233
|
-
```
|
|
234
|
-
|
|
235
|
-
#### Parameters
|
|
236
|
-
|
|
237
|
-
- `method` **[string][8]** request method. Can be `GET`, `POST`, `PUT`, etc or `ANY`.
|
|
238
|
-
- `oneOrMoreUrls` **([string][8] \| [Array][9]<[string][8]>)** url(s) to mock. Can be exact URL, a pattern, or an array of URLs.
|
|
239
|
-
- `dataOrStatusCode` **([number][10] \| [string][8] \| [object][11])** status code when number provided. A response body otherwise
|
|
240
|
-
- `additionalData` **([string][8] \| [object][11])** response body when a status code is set by previous parameter. (optional, default `null`)
|
|
241
|
-
|
|
242
|
-
### mockServer
|
|
243
|
-
|
|
244
|
-
Use PollyJS [Server Routes API][12] to declare mocks via callback function:
|
|
245
|
-
|
|
246
|
-
```js
|
|
247
|
-
I.mockServer((server) => {
|
|
248
|
-
// basic usage
|
|
249
|
-
server.get('/api/v2/users').intercept((req, res) => {
|
|
250
|
-
res.sendStatus(200).json({ users });
|
|
251
|
-
});
|
|
252
|
-
|
|
253
|
-
// passthrough requests to "/api/v2"
|
|
254
|
-
server.get('/api/v1').passthrough();
|
|
255
|
-
});
|
|
256
|
-
```
|
|
257
|
-
|
|
258
|
-
In record replay mode you can define which routes should be recorded and where to store them:
|
|
259
|
-
|
|
260
|
-
```js
|
|
261
|
-
I.startMocking('mock');
|
|
262
|
-
I.mockServer((server) => {
|
|
263
|
-
|
|
264
|
-
// record requests from cdn1.com and save them to data/recording/xml
|
|
265
|
-
server.any('https://cdn1.com/*').passthrough(false).recordingName('xml');
|
|
266
|
-
|
|
267
|
-
// record requests from cdn2.com and save them to data/recording/svg
|
|
268
|
-
server.any('https://cdn2.com/*').passthrough(false).recordingName('svg');
|
|
269
|
-
|
|
270
|
-
// record requests from /api and save them to data/recording/mock (default)
|
|
271
|
-
server.any('/api/*').passthrough(false);
|
|
272
|
-
});
|
|
273
|
-
```
|
|
274
|
-
|
|
275
|
-
#### Parameters
|
|
276
|
-
|
|
277
|
-
- `configFn`
|
|
278
|
-
|
|
279
|
-
### passthroughMocking
|
|
280
|
-
|
|
281
|
-
Forces passthrough mode for mocking.
|
|
282
|
-
Requires mocking to be started.
|
|
283
|
-
|
|
284
|
-
```js
|
|
285
|
-
I.passthroughMocking();
|
|
286
|
-
```
|
|
287
|
-
|
|
288
|
-
### recordMocking
|
|
289
|
-
|
|
290
|
-
Forces record mode for mocking.
|
|
291
|
-
Requires mocking to be started.
|
|
292
|
-
|
|
293
|
-
```js
|
|
294
|
-
I.recordMocking();
|
|
295
|
-
```
|
|
296
|
-
|
|
297
|
-
### replayMocking
|
|
298
|
-
|
|
299
|
-
Forces replay mode for mocking.
|
|
300
|
-
Requires mocking to be started.
|
|
301
|
-
|
|
302
|
-
```js
|
|
303
|
-
I.replayMocking();
|
|
304
|
-
```
|
|
305
|
-
|
|
306
|
-
### startMocking
|
|
307
|
-
|
|
308
|
-
Starts mocking of http requests.
|
|
309
|
-
In record mode starts recording of all requests.
|
|
310
|
-
In replay mode blocks all requests and replaces them with saved.
|
|
311
|
-
|
|
312
|
-
If inside one test you plan to record/replay requests in several places, provide [recording name][13] as the parameter.
|
|
313
|
-
|
|
314
|
-
```js
|
|
315
|
-
// start mocking requests for a test
|
|
316
|
-
I.startMocking();
|
|
317
|
-
|
|
318
|
-
// start mocking requests for main page
|
|
319
|
-
I.startMocking('main-page');
|
|
320
|
-
// do actions
|
|
321
|
-
I.stopMocking();
|
|
322
|
-
I.startMocking('login-page');
|
|
323
|
-
```
|
|
324
|
-
|
|
325
|
-
To update [PollyJS configuration][14] use secon argument:
|
|
326
|
-
|
|
327
|
-
```js
|
|
328
|
-
// change mode
|
|
329
|
-
I.startMocking('comments', { mode: 'replay' });
|
|
330
|
-
|
|
331
|
-
// override config
|
|
332
|
-
I.startMocking('users-loaded', {
|
|
333
|
-
recordFailedRequests: true
|
|
334
|
-
})
|
|
335
|
-
```
|
|
336
|
-
|
|
337
|
-
#### Parameters
|
|
338
|
-
|
|
339
|
-
- `title` **any** (optional, default `'Test'`)
|
|
340
|
-
- `config` (optional, default `{}`)
|
|
341
|
-
|
|
342
|
-
### stopMocking
|
|
343
|
-
|
|
344
|
-
Stops mocking requests.
|
|
345
|
-
Must be called to save recorded requests into faile.
|
|
346
|
-
|
|
347
|
-
```js
|
|
348
|
-
I.stopMocking();
|
|
349
|
-
```
|
|
350
|
-
|
|
351
|
-
[1]: https://netflix.github.io/pollyjs/#/configuration?id=mode
|
|
352
|
-
|
|
353
|
-
[2]: https://netflix.github.io/pollyjs/#/configuration?id=configuration
|
|
354
|
-
|
|
355
|
-
[3]: https://netflix.github.io/pollyjs/#/examples?id=rest-persister
|
|
356
|
-
|
|
357
|
-
[4]: #startMocking
|
|
358
|
-
|
|
359
|
-
[5]: #mockRequest
|
|
360
|
-
|
|
361
|
-
[6]: #mockServer
|
|
362
|
-
|
|
363
|
-
[7]: #stopMocking
|
|
364
|
-
|
|
365
|
-
[8]: https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String
|
|
366
|
-
|
|
367
|
-
[9]: https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array
|
|
368
|
-
|
|
369
|
-
[10]: https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number
|
|
370
|
-
|
|
371
|
-
[11]: https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object
|
|
372
|
-
|
|
373
|
-
[12]: https://netflix.github.io/pollyjs/#/server/overview
|
|
374
|
-
|
|
375
|
-
[13]: https://netflix.github.io/pollyjs/#/api?id=recordingname
|
|
376
|
-
|
|
377
|
-
[14]: https://netflix.github.io/pollyjs/#/configuration
|