codeceptjs 3.4.1 → 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.
Files changed (281) hide show
  1. package/README.md +31 -30
  2. package/bin/codecept.js +1 -1
  3. package/lib/actor.js +6 -3
  4. package/lib/ai.js +180 -0
  5. package/lib/cli.js +13 -3
  6. package/lib/codecept.js +8 -0
  7. package/lib/colorUtils.js +10 -0
  8. package/lib/command/definitions.js +2 -7
  9. package/lib/command/dryRun.js +11 -2
  10. package/lib/command/generate.js +46 -3
  11. package/lib/command/info.js +24 -0
  12. package/lib/command/init.js +64 -6
  13. package/lib/command/interactive.js +15 -1
  14. package/lib/command/run-multiple/collection.js +17 -5
  15. package/lib/command/run-multiple.js +4 -2
  16. package/lib/command/run-workers.js +68 -5
  17. package/lib/command/run.js +7 -0
  18. package/lib/command/workers/runTests.js +39 -0
  19. package/lib/container.js +13 -3
  20. package/lib/data/context.js +14 -6
  21. package/lib/event.js +4 -0
  22. package/lib/helper/ApiDataFactory.js +2 -1
  23. package/lib/helper/Appium.js +116 -29
  24. package/lib/helper/Expect.js +422 -0
  25. package/lib/helper/FileSystem.js +1 -1
  26. package/lib/helper/GraphQL.js +25 -0
  27. package/lib/helper/JSONResponse.js +4 -4
  28. package/lib/helper/Nightmare.js +10 -5
  29. package/lib/helper/OpenAI.js +126 -0
  30. package/lib/helper/Playwright.js +1298 -229
  31. package/lib/helper/Protractor.js +12 -7
  32. package/lib/helper/Puppeteer.js +204 -64
  33. package/lib/helper/REST.js +15 -5
  34. package/lib/helper/TestCafe.js +45 -10
  35. package/lib/helper/WebDriver.js +252 -83
  36. package/lib/helper/errors/ElementNotFound.js +2 -1
  37. package/lib/helper/extras/PlaywrightReactVueLocator.js +38 -0
  38. package/lib/helper/scripts/blurElement.js +17 -0
  39. package/lib/helper/scripts/focusElement.js +17 -0
  40. package/lib/helper/scripts/highlightElement.js +20 -0
  41. package/lib/html.js +258 -0
  42. package/lib/interfaces/bdd.js +1 -1
  43. package/lib/interfaces/gherkin.js +37 -3
  44. package/lib/interfaces/scenarioConfig.js +1 -0
  45. package/lib/listener/retry.js +2 -1
  46. package/lib/locator.js +17 -4
  47. package/lib/mochaFactory.js +2 -1
  48. package/lib/output.js +1 -1
  49. package/lib/pause.js +78 -19
  50. package/lib/plugin/autoLogin.js +45 -10
  51. package/lib/plugin/debugErrors.js +67 -0
  52. package/lib/plugin/fakerTransform.js +4 -6
  53. package/lib/plugin/heal.js +209 -0
  54. package/lib/plugin/retryFailedStep.js +10 -1
  55. package/lib/plugin/retryTo.js +2 -4
  56. package/lib/plugin/screenshotOnFail.js +11 -2
  57. package/lib/plugin/selenoid.js +6 -1
  58. package/lib/plugin/standardActingHelpers.js +0 -2
  59. package/lib/plugin/stepByStepReport.js +2 -2
  60. package/lib/plugin/tryTo.js +5 -7
  61. package/lib/plugin/wdio.js +0 -1
  62. package/lib/recorder.js +22 -11
  63. package/lib/secret.js +5 -4
  64. package/lib/session.js +1 -1
  65. package/lib/step.js +36 -12
  66. package/lib/ui.js +5 -3
  67. package/lib/utils.js +22 -1
  68. package/lib/workers.js +83 -10
  69. package/package.json +117 -95
  70. package/translations/de-DE.js +5 -0
  71. package/translations/fr-FR.js +14 -1
  72. package/translations/it-IT.js +1 -0
  73. package/translations/ja-JP.js +14 -9
  74. package/translations/pl-PL.js +5 -0
  75. package/translations/pt-BR.js +1 -0
  76. package/translations/ru-RU.js +1 -0
  77. package/translations/zh-CN.js +5 -0
  78. package/translations/zh-TW.js +5 -0
  79. package/typings/index.d.ts +51 -15
  80. package/typings/promiseBasedTypes.d.ts +864 -802
  81. package/typings/types.d.ts +1339 -744
  82. package/CHANGELOG.md +0 -2427
  83. package/docs/advanced.md +0 -351
  84. package/docs/api.md +0 -323
  85. package/docs/basics.md +0 -980
  86. package/docs/bdd.md +0 -535
  87. package/docs/best.md +0 -237
  88. package/docs/books.md +0 -37
  89. package/docs/bootstrap.md +0 -135
  90. package/docs/build/ApiDataFactory.js +0 -409
  91. package/docs/build/Appium.js +0 -1938
  92. package/docs/build/FileSystem.js +0 -228
  93. package/docs/build/GraphQL.js +0 -204
  94. package/docs/build/GraphQLDataFactory.js +0 -309
  95. package/docs/build/JSONResponse.js +0 -338
  96. package/docs/build/Mochawesome.js +0 -71
  97. package/docs/build/Nightmare.js +0 -2145
  98. package/docs/build/Playwright.js +0 -3986
  99. package/docs/build/Polly.js +0 -42
  100. package/docs/build/Protractor.js +0 -2699
  101. package/docs/build/Puppeteer.js +0 -3710
  102. package/docs/build/REST.js +0 -334
  103. package/docs/build/SeleniumWebdriver.js +0 -76
  104. package/docs/build/TestCafe.js +0 -2057
  105. package/docs/build/WebDriver.js +0 -4017
  106. package/docs/changelog.md +0 -2436
  107. package/docs/commands.md +0 -254
  108. package/docs/community-helpers.md +0 -58
  109. package/docs/configuration.md +0 -157
  110. package/docs/continuous-integration.md +0 -22
  111. package/docs/custom-helpers.md +0 -306
  112. package/docs/data.md +0 -375
  113. package/docs/detox.md +0 -235
  114. package/docs/docker.md +0 -137
  115. package/docs/email.md +0 -183
  116. package/docs/examples.md +0 -149
  117. package/docs/helpers/ApiDataFactory.md +0 -266
  118. package/docs/helpers/Appium.md +0 -1312
  119. package/docs/helpers/Detox.md +0 -586
  120. package/docs/helpers/FileSystem.md +0 -152
  121. package/docs/helpers/GraphQL.md +0 -130
  122. package/docs/helpers/GraphQLDataFactory.md +0 -226
  123. package/docs/helpers/JSONResponse.md +0 -254
  124. package/docs/helpers/Mochawesome.md +0 -8
  125. package/docs/helpers/MockRequest.md +0 -377
  126. package/docs/helpers/Nightmare.md +0 -1256
  127. package/docs/helpers/Playwright.md +0 -2208
  128. package/docs/helpers/Polly.md +0 -44
  129. package/docs/helpers/Puppeteer-firefox.md +0 -86
  130. package/docs/helpers/Puppeteer.md +0 -2141
  131. package/docs/helpers/REST.md +0 -217
  132. package/docs/helpers/TestCafe.md +0 -1222
  133. package/docs/helpers/WebDriver.md +0 -2319
  134. package/docs/hooks.md +0 -340
  135. package/docs/index.md +0 -111
  136. package/docs/installation.md +0 -75
  137. package/docs/internal-api.md +0 -265
  138. package/docs/locators.md +0 -331
  139. package/docs/mobile-react-native-locators.md +0 -67
  140. package/docs/mobile.md +0 -297
  141. package/docs/nightmare.md +0 -223
  142. package/docs/pageobjects.md +0 -291
  143. package/docs/parallel.md +0 -232
  144. package/docs/playwright.md +0 -609
  145. package/docs/plugins.md +0 -1171
  146. package/docs/puppeteer.md +0 -316
  147. package/docs/quickstart.md +0 -163
  148. package/docs/react.md +0 -69
  149. package/docs/reports.md +0 -392
  150. package/docs/secrets.md +0 -30
  151. package/docs/shadow.md +0 -68
  152. package/docs/shared/keys.mustache +0 -31
  153. package/docs/shared/react.mustache +0 -1
  154. package/docs/testcafe.md +0 -174
  155. package/docs/translation.md +0 -247
  156. package/docs/tutorial.md +0 -271
  157. package/docs/typescript.md +0 -180
  158. package/docs/ui.md +0 -59
  159. package/docs/videos.md +0 -28
  160. package/docs/visual.md +0 -202
  161. package/docs/vue.md +0 -121
  162. package/docs/webapi/amOnPage.mustache +0 -11
  163. package/docs/webapi/appendField.mustache +0 -9
  164. package/docs/webapi/attachFile.mustache +0 -12
  165. package/docs/webapi/checkOption.mustache +0 -13
  166. package/docs/webapi/clearCookie.mustache +0 -10
  167. package/docs/webapi/clearField.mustache +0 -9
  168. package/docs/webapi/click.mustache +0 -25
  169. package/docs/webapi/clickLink.mustache +0 -8
  170. package/docs/webapi/closeCurrentTab.mustache +0 -7
  171. package/docs/webapi/closeOtherTabs.mustache +0 -8
  172. package/docs/webapi/dontSee.mustache +0 -11
  173. package/docs/webapi/dontSeeCheckboxIsChecked.mustache +0 -10
  174. package/docs/webapi/dontSeeCookie.mustache +0 -8
  175. package/docs/webapi/dontSeeCurrentUrlEquals.mustache +0 -10
  176. package/docs/webapi/dontSeeElement.mustache +0 -8
  177. package/docs/webapi/dontSeeElementInDOM.mustache +0 -8
  178. package/docs/webapi/dontSeeInCurrentUrl.mustache +0 -4
  179. package/docs/webapi/dontSeeInField.mustache +0 -11
  180. package/docs/webapi/dontSeeInSource.mustache +0 -8
  181. package/docs/webapi/dontSeeInTitle.mustache +0 -8
  182. package/docs/webapi/doubleClick.mustache +0 -13
  183. package/docs/webapi/downloadFile.mustache +0 -12
  184. package/docs/webapi/dragAndDrop.mustache +0 -9
  185. package/docs/webapi/dragSlider.mustache +0 -11
  186. package/docs/webapi/executeAsyncScript.mustache +0 -24
  187. package/docs/webapi/executeScript.mustache +0 -26
  188. package/docs/webapi/fillField.mustache +0 -16
  189. package/docs/webapi/forceClick.mustache +0 -28
  190. package/docs/webapi/forceRightClick.mustache +0 -18
  191. package/docs/webapi/grabAllWindowHandles.mustache +0 -7
  192. package/docs/webapi/grabAttributeFrom.mustache +0 -10
  193. package/docs/webapi/grabAttributeFromAll.mustache +0 -9
  194. package/docs/webapi/grabBrowserLogs.mustache +0 -9
  195. package/docs/webapi/grabCookie.mustache +0 -11
  196. package/docs/webapi/grabCssPropertyFrom.mustache +0 -11
  197. package/docs/webapi/grabCssPropertyFromAll.mustache +0 -10
  198. package/docs/webapi/grabCurrentUrl.mustache +0 -9
  199. package/docs/webapi/grabCurrentWindowHandle.mustache +0 -6
  200. package/docs/webapi/grabDataFromPerformanceTiming.mustache +0 -20
  201. package/docs/webapi/grabElementBoundingRect.mustache +0 -20
  202. package/docs/webapi/grabGeoLocation.mustache +0 -8
  203. package/docs/webapi/grabHTMLFrom.mustache +0 -10
  204. package/docs/webapi/grabHTMLFromAll.mustache +0 -9
  205. package/docs/webapi/grabNumberOfOpenTabs.mustache +0 -8
  206. package/docs/webapi/grabNumberOfVisibleElements.mustache +0 -9
  207. package/docs/webapi/grabPageScrollPosition.mustache +0 -8
  208. package/docs/webapi/grabPopupText.mustache +0 -5
  209. package/docs/webapi/grabSource.mustache +0 -8
  210. package/docs/webapi/grabTextFrom.mustache +0 -10
  211. package/docs/webapi/grabTextFromAll.mustache +0 -9
  212. package/docs/webapi/grabTitle.mustache +0 -8
  213. package/docs/webapi/grabValueFrom.mustache +0 -9
  214. package/docs/webapi/grabValueFromAll.mustache +0 -8
  215. package/docs/webapi/moveCursorTo.mustache +0 -12
  216. package/docs/webapi/openNewTab.mustache +0 -7
  217. package/docs/webapi/pressKey.mustache +0 -12
  218. package/docs/webapi/pressKeyDown.mustache +0 -12
  219. package/docs/webapi/pressKeyUp.mustache +0 -12
  220. package/docs/webapi/pressKeyWithKeyNormalization.mustache +0 -60
  221. package/docs/webapi/refreshPage.mustache +0 -6
  222. package/docs/webapi/resizeWindow.mustache +0 -6
  223. package/docs/webapi/rightClick.mustache +0 -14
  224. package/docs/webapi/saveElementScreenshot.mustache +0 -10
  225. package/docs/webapi/saveScreenshot.mustache +0 -12
  226. package/docs/webapi/say.mustache +0 -10
  227. package/docs/webapi/scrollIntoView.mustache +0 -11
  228. package/docs/webapi/scrollPageToBottom.mustache +0 -6
  229. package/docs/webapi/scrollPageToTop.mustache +0 -6
  230. package/docs/webapi/scrollTo.mustache +0 -12
  231. package/docs/webapi/see.mustache +0 -11
  232. package/docs/webapi/seeAttributesOnElements.mustache +0 -9
  233. package/docs/webapi/seeCheckboxIsChecked.mustache +0 -10
  234. package/docs/webapi/seeCookie.mustache +0 -8
  235. package/docs/webapi/seeCssPropertiesOnElements.mustache +0 -9
  236. package/docs/webapi/seeCurrentUrlEquals.mustache +0 -11
  237. package/docs/webapi/seeElement.mustache +0 -8
  238. package/docs/webapi/seeElementInDOM.mustache +0 -8
  239. package/docs/webapi/seeInCurrentUrl.mustache +0 -8
  240. package/docs/webapi/seeInField.mustache +0 -12
  241. package/docs/webapi/seeInPopup.mustache +0 -8
  242. package/docs/webapi/seeInSource.mustache +0 -7
  243. package/docs/webapi/seeInTitle.mustache +0 -8
  244. package/docs/webapi/seeNumberOfElements.mustache +0 -11
  245. package/docs/webapi/seeNumberOfVisibleElements.mustache +0 -10
  246. package/docs/webapi/seeTextEquals.mustache +0 -9
  247. package/docs/webapi/seeTitleEquals.mustache +0 -8
  248. package/docs/webapi/selectOption.mustache +0 -21
  249. package/docs/webapi/setCookie.mustache +0 -16
  250. package/docs/webapi/setGeoLocation.mustache +0 -12
  251. package/docs/webapi/switchTo.mustache +0 -9
  252. package/docs/webapi/switchToNextTab.mustache +0 -10
  253. package/docs/webapi/switchToPreviousTab.mustache +0 -10
  254. package/docs/webapi/type.mustache +0 -18
  255. package/docs/webapi/uncheckOption.mustache +0 -13
  256. package/docs/webapi/wait.mustache +0 -8
  257. package/docs/webapi/waitForClickable.mustache +0 -11
  258. package/docs/webapi/waitForDetached.mustache +0 -10
  259. package/docs/webapi/waitForElement.mustache +0 -11
  260. package/docs/webapi/waitForEnabled.mustache +0 -6
  261. package/docs/webapi/waitForFunction.mustache +0 -17
  262. package/docs/webapi/waitForInvisible.mustache +0 -10
  263. package/docs/webapi/waitForText.mustache +0 -13
  264. package/docs/webapi/waitForValue.mustache +0 -10
  265. package/docs/webapi/waitForVisible.mustache +0 -10
  266. package/docs/webapi/waitInUrl.mustache +0 -9
  267. package/docs/webapi/waitNumberOfVisibleElements.mustache +0 -10
  268. package/docs/webapi/waitToHide.mustache +0 -10
  269. package/docs/webapi/waitUrlEquals.mustache +0 -10
  270. package/docs/webdriver.md +0 -657
  271. package/docs/wiki/Books-&-Posts.md +0 -27
  272. package/docs/wiki/Community-Helpers-&-Plugins.md +0 -49
  273. package/docs/wiki/Converting-Playwright-to-Istanbul-Coverage.md +0 -29
  274. package/docs/wiki/Examples.md +0 -139
  275. package/docs/wiki/Google-Summer-of-Code-(GSoC)-2020.md +0 -68
  276. package/docs/wiki/Home.md +0 -16
  277. package/docs/wiki/Release-Process.md +0 -24
  278. package/docs/wiki/Roadmap.md +0 -23
  279. package/docs/wiki/Tests.md +0 -1393
  280. package/docs/wiki/Upgrading-to-CodeceptJS-3.md +0 -153
  281. 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,8 +0,0 @@
1
- ---
2
- permalink: /helpers/Mochawesome
3
- editLink: false
4
- sidebar: auto
5
- title: Mochawesome
6
- ---
7
-
8
- <!-- Generated by documentation.js. Update this documentation by updating the source code. -->
@@ -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]&lt;[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