codeceptjs 3.6.0-beta.1.ai-healers → 3.6.1

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 (130) hide show
  1. package/README.md +2 -2
  2. package/bin/codecept.js +2 -1
  3. package/docs/webapi/dontSeeTraffic.mustache +13 -0
  4. package/docs/webapi/flushNetworkTraffics.mustache +5 -0
  5. package/docs/webapi/grabRecordedNetworkTraffics.mustache +10 -0
  6. package/docs/webapi/seeTraffic.mustache +36 -0
  7. package/docs/webapi/startRecordingTraffic.mustache +8 -0
  8. package/docs/webapi/startRecordingWebSocketMessages.mustache +8 -0
  9. package/docs/webapi/stopRecordingTraffic.mustache +5 -0
  10. package/docs/webapi/stopRecordingWebSocketMessages.mustache +7 -0
  11. package/docs/webapi/waitForCookie.mustache +9 -0
  12. package/lib/actor.js +6 -3
  13. package/lib/command/dryRun.js +44 -13
  14. package/lib/helper/Appium.js +36 -12
  15. package/lib/helper/Expect.js +11 -8
  16. package/lib/helper/JSONResponse.js +8 -8
  17. package/lib/helper/MockServer.js +221 -0
  18. package/lib/helper/Playwright.js +107 -371
  19. package/lib/helper/Puppeteer.js +404 -71
  20. package/lib/helper/REST.js +4 -1
  21. package/lib/helper/WebDriver.js +189 -13
  22. package/lib/helper/errors/ElementAssertion.js +38 -0
  23. package/lib/helper/extras/PlaywrightReactVueLocator.js +6 -1
  24. package/lib/helper/network/actions.js +123 -0
  25. package/lib/helper/network/utils.js +187 -0
  26. package/lib/locator.js +36 -5
  27. package/lib/pause.js +4 -9
  28. package/lib/plugin/coverage.js +112 -99
  29. package/lib/step.js +3 -1
  30. package/package.json +49 -38
  31. package/typings/index.d.ts +19 -2
  32. package/typings/promiseBasedTypes.d.ts +505 -41
  33. package/typings/types.d.ts +531 -43
  34. package/docs/advanced.md +0 -351
  35. package/docs/ai.md +0 -365
  36. package/docs/api.md +0 -323
  37. package/docs/basics.md +0 -979
  38. package/docs/bdd.md +0 -539
  39. package/docs/best.md +0 -237
  40. package/docs/books.md +0 -37
  41. package/docs/bootstrap.md +0 -135
  42. package/docs/build/AI.js +0 -124
  43. package/docs/build/ApiDataFactory.js +0 -410
  44. package/docs/build/Appium.js +0 -2027
  45. package/docs/build/Expect.js +0 -422
  46. package/docs/build/FileSystem.js +0 -228
  47. package/docs/build/GraphQL.js +0 -229
  48. package/docs/build/GraphQLDataFactory.js +0 -309
  49. package/docs/build/JSONResponse.js +0 -338
  50. package/docs/build/Mochawesome.js +0 -71
  51. package/docs/build/Nightmare.js +0 -2152
  52. package/docs/build/OpenAI.js +0 -126
  53. package/docs/build/Playwright.js +0 -5110
  54. package/docs/build/Protractor.js +0 -2706
  55. package/docs/build/Puppeteer.js +0 -3905
  56. package/docs/build/REST.js +0 -344
  57. package/docs/build/TestCafe.js +0 -2125
  58. package/docs/build/WebDriver.js +0 -4240
  59. package/docs/changelog.md +0 -2572
  60. package/docs/commands.md +0 -266
  61. package/docs/community-helpers.md +0 -58
  62. package/docs/configuration.md +0 -157
  63. package/docs/continuous-integration.md +0 -22
  64. package/docs/custom-helpers.md +0 -306
  65. package/docs/data.md +0 -379
  66. package/docs/detox.md +0 -235
  67. package/docs/docker.md +0 -136
  68. package/docs/email.md +0 -183
  69. package/docs/examples.md +0 -149
  70. package/docs/heal.md +0 -186
  71. package/docs/helpers/ApiDataFactory.md +0 -266
  72. package/docs/helpers/Appium.md +0 -1374
  73. package/docs/helpers/Detox.md +0 -586
  74. package/docs/helpers/Expect.md +0 -275
  75. package/docs/helpers/FileSystem.md +0 -152
  76. package/docs/helpers/GraphQL.md +0 -151
  77. package/docs/helpers/GraphQLDataFactory.md +0 -226
  78. package/docs/helpers/JSONResponse.md +0 -254
  79. package/docs/helpers/Mochawesome.md +0 -8
  80. package/docs/helpers/MockRequest.md +0 -377
  81. package/docs/helpers/Nightmare.md +0 -1305
  82. package/docs/helpers/OpenAI.md +0 -70
  83. package/docs/helpers/Playwright.md +0 -2759
  84. package/docs/helpers/Polly.md +0 -44
  85. package/docs/helpers/Protractor.md +0 -1769
  86. package/docs/helpers/Puppeteer-firefox.md +0 -86
  87. package/docs/helpers/Puppeteer.md +0 -2317
  88. package/docs/helpers/REST.md +0 -218
  89. package/docs/helpers/TestCafe.md +0 -1321
  90. package/docs/helpers/WebDriver.md +0 -2547
  91. package/docs/hooks.md +0 -340
  92. package/docs/index.md +0 -111
  93. package/docs/installation.md +0 -75
  94. package/docs/internal-api.md +0 -266
  95. package/docs/locators.md +0 -339
  96. package/docs/mobile-react-native-locators.md +0 -67
  97. package/docs/mobile.md +0 -338
  98. package/docs/pageobjects.md +0 -291
  99. package/docs/parallel.md +0 -400
  100. package/docs/playwright.md +0 -632
  101. package/docs/plugins.md +0 -1247
  102. package/docs/puppeteer.md +0 -316
  103. package/docs/quickstart.md +0 -162
  104. package/docs/react.md +0 -70
  105. package/docs/reports.md +0 -392
  106. package/docs/secrets.md +0 -36
  107. package/docs/shadow.md +0 -68
  108. package/docs/shared/keys.mustache +0 -31
  109. package/docs/shared/react.mustache +0 -1
  110. package/docs/testcafe.md +0 -174
  111. package/docs/translation.md +0 -247
  112. package/docs/tutorial.md +0 -271
  113. package/docs/typescript.md +0 -180
  114. package/docs/ui.md +0 -59
  115. package/docs/videos.md +0 -28
  116. package/docs/visual.md +0 -202
  117. package/docs/vue.md +0 -143
  118. package/docs/webdriver.md +0 -701
  119. package/docs/wiki/Books-&-Posts.md +0 -27
  120. package/docs/wiki/Community-Helpers-&-Plugins.md +0 -53
  121. package/docs/wiki/Converting-Playwright-to-Istanbul-Coverage.md +0 -61
  122. package/docs/wiki/Examples.md +0 -145
  123. package/docs/wiki/Google-Summer-of-Code-(GSoC)-2020.md +0 -68
  124. package/docs/wiki/Home.md +0 -16
  125. package/docs/wiki/Migration-to-Appium-v2---CodeceptJS.md +0 -83
  126. package/docs/wiki/Release-Process.md +0 -24
  127. package/docs/wiki/Roadmap.md +0 -23
  128. package/docs/wiki/Tests.md +0 -1393
  129. package/docs/wiki/Upgrading-to-CodeceptJS-3.md +0 -153
  130. package/docs/wiki/Videos.md +0 -19
@@ -1,344 +0,0 @@
1
- const axios = require('axios').default;
2
- const Helper = require('@codeceptjs/helper');
3
- const Secret = require('../secret');
4
-
5
- const { beautify } = require('../utils');
6
-
7
- /**
8
- * ## Configuration
9
- *
10
- * @typedef RESTConfig
11
- * @type {object}
12
- * @prop {string} [endpoint] - API base URL
13
- * @prop {boolean} [prettyPrintJson=false] - pretty print json for response/request on console logs
14
- * @prop {number} [timeout=1000] - timeout for requests in milliseconds. 10000ms by default
15
- * @prop {object} [defaultHeaders] - a list of default headers
16
- * @prop {function} [onRequest] - a async function which can update request object.
17
- * @prop {function} [onResponse] - a async function which can update response object.
18
- * @prop {number} [maxUploadFileSize] - set the max content file size in MB when performing api calls.
19
- */
20
- const config = {};
21
-
22
- /**
23
- * REST helper allows to send additional requests to the REST API during acceptance tests.
24
- * [Axios](https://github.com/axios/axios) library is used to perform requests.
25
- *
26
- * <!-- configuration -->
27
- *
28
- * ## Example
29
- *
30
- * ```js
31
- *{
32
- * helpers: {
33
- * REST: {
34
- * endpoint: 'http://site.com/api',
35
- * prettyPrintJson: true,
36
- * onRequest: (request) => {
37
- * request.headers.auth = '123';
38
- * }
39
- * }
40
- * }
41
- *}
42
- * ```
43
- *
44
- * ## Access From Helpers
45
- *
46
- * Send REST requests by accessing `_executeRequest` method:
47
- *
48
- * ```js
49
- * this.helpers['REST']._executeRequest({
50
- * url,
51
- * data,
52
- * });
53
- * ```
54
- *
55
- * ## Methods
56
- */
57
- class REST extends Helper {
58
- constructor(config) {
59
- super(config);
60
- this.options = {
61
- timeout: 10000,
62
- defaultHeaders: {},
63
- endpoint: '',
64
- prettyPrintJson: false,
65
- onRequest: null,
66
- onResponse: null,
67
- };
68
-
69
- if (this.options.maxContentLength) {
70
- const maxContentLength = this.options.maxUploadFileSize * 1024 * 1024;
71
- this.options.maxContentLength = maxContentLength;
72
- this.options.maxBodyLength = maxContentLength;
73
- }
74
-
75
- this.options = { ...this.options, ...config };
76
- this.headers = { ...this.options.defaultHeaders };
77
- this.axios = axios.create();
78
- this.axios.defaults.headers = this.options.defaultHeaders;
79
- }
80
-
81
- static _config() {
82
- return [
83
- { name: 'endpoint', message: 'Endpoint of API you are going to test', default: 'http://localhost:3000/api' },
84
- ];
85
- }
86
-
87
- static _checkRequirements() {
88
- try {
89
- require('axios');
90
- } catch (e) {
91
- return ['axios'];
92
- }
93
- }
94
-
95
- _before() {
96
- this.headers = { ...this.options.defaultHeaders };
97
- }
98
-
99
- /**
100
- * Sets request headers for all requests of this test
101
- *
102
- * @param {object} headers headers list
103
- */
104
- haveRequestHeaders(headers) {
105
- this.headers = { ...this.headers, ...headers };
106
- }
107
-
108
- /**
109
- * Adds a header for Bearer authentication
110
- *
111
- * ```js
112
- * // we use secret function to hide token from logs
113
- * I.amBearerAuthenticated(secret('heregoestoken'))
114
- * ```
115
- *
116
- * @param {string | CodeceptJS.Secret} accessToken Bearer access token
117
- */
118
- amBearerAuthenticated(accessToken) {
119
- this.haveRequestHeaders({ Authorization: `Bearer ${accessToken}` });
120
- }
121
-
122
- /**
123
- * Executes axios request
124
- *
125
- * @param {*} request
126
- *
127
- * @returns {Promise<*>} response
128
- */
129
- async _executeRequest(request) {
130
- // Add custom headers. They can be set by amBearerAuthenticated() or haveRequestHeaders()
131
- request.headers = { ...this.headers, ...request.headers };
132
-
133
- const _debugRequest = { ...request };
134
- this.axios.defaults.timeout = request.timeout || this.options.timeout;
135
-
136
- if (this.headers && this.headers.auth) {
137
- request.auth = this.headers.auth;
138
- }
139
-
140
- if (typeof request.data === 'object') {
141
- const returnedValue = {};
142
- for (const [key, value] of Object.entries(request.data)) {
143
- returnedValue[key] = value;
144
- if (value instanceof Secret) returnedValue[key] = value.getMasked();
145
- }
146
- _debugRequest.data = returnedValue;
147
- }
148
-
149
- if (request.data instanceof Secret) {
150
- _debugRequest.data = '*****';
151
- request.data = (typeof request.data === 'object' && !(request.data instanceof Secret)) ? { ...request.data.toString() } : request.data.toString();
152
- }
153
-
154
- if ((typeof request.data) === 'string') {
155
- if (!request.headers || !request.headers['Content-Type']) {
156
- request.headers = { ...request.headers, ...{ 'Content-Type': 'application/x-www-form-urlencoded' } };
157
- }
158
- }
159
-
160
- if (this.config.onRequest) {
161
- await this.config.onRequest(request);
162
- }
163
-
164
- this.options.prettyPrintJson ? this.debugSection('Request', beautify(JSON.stringify(_debugRequest))) : this.debugSection('Request', JSON.stringify(_debugRequest));
165
-
166
- let response;
167
- try {
168
- response = await this.axios(request);
169
- } catch (err) {
170
- if (!err.response) throw err;
171
- this.debugSection('Response', `Response error. Status code: ${err.response.status}`);
172
- response = err.response;
173
- }
174
- if (this.config.onResponse) {
175
- await this.config.onResponse(response);
176
- }
177
- this.options.prettyPrintJson ? this.debugSection('Response', beautify(JSON.stringify(response.data))) : this.debugSection('Response', JSON.stringify(response.data));
178
- return response;
179
- }
180
-
181
- /**
182
- * Generates url based on format sent (takes endpoint + url if latter lacks 'http')
183
- *
184
- * @param {*} url
185
- */
186
- _url(url) {
187
- return /^\w+\:\/\//.test(url) ? url : this.options.endpoint + url;
188
- }
189
-
190
- /**
191
- * Set timeout for the request
192
- *
193
- * ```js
194
- * I.setRequestTimeout(10000); // In milliseconds
195
- * ```
196
- *
197
- * @param {number} newTimeout - timeout in milliseconds
198
- */
199
- setRequestTimeout(newTimeout) {
200
- this.options.timeout = newTimeout;
201
- }
202
-
203
- /**
204
- * Send GET request to REST API
205
- *
206
- * ```js
207
- * I.sendGetRequest('/api/users.json');
208
- * ```
209
- *
210
- * @param {*} url
211
- * @param {object} [headers={}] - the headers object to be sent. By default, it is sent as an empty object
212
- *
213
- * @returns {Promise<*>} response
214
- */
215
- async sendGetRequest(url, headers = {}) {
216
- const request = {
217
- baseURL: this._url(url),
218
- headers,
219
- };
220
- return this._executeRequest(request);
221
- }
222
-
223
- /**
224
- * Sends POST request to API.
225
- *
226
- * ```js
227
- * I.sendPostRequest('/api/users.json', { "email": "user@user.com" });
228
- *
229
- * // To mask the payload in logs
230
- * I.sendPostRequest('/api/users.json', secret({ "email": "user@user.com" }));
231
- *
232
- * ```
233
- *
234
- * @param {*} url
235
- * @param {*} [payload={}] - the payload to be sent. By default, it is sent as an empty object
236
- * @param {object} [headers={}] - the headers object to be sent. By default, it is sent as an empty object
237
- *
238
- * @returns {Promise<*>} response
239
- */
240
- async sendPostRequest(url, payload = {}, headers = {}) {
241
- const request = {
242
- baseURL: this._url(url),
243
- method: 'POST',
244
- data: payload,
245
- headers,
246
- };
247
-
248
- if (this.options.maxContentLength) {
249
- request.maxContentLength = this.options.maxContentLength;
250
- request.maxBodyLength = this.options.maxContentLength;
251
- }
252
-
253
- return this._executeRequest(request);
254
- }
255
-
256
- /**
257
- * Sends PATCH request to API.
258
- *
259
- * ```js
260
- * I.sendPatchRequest('/api/users.json', { "email": "user@user.com" });
261
- *
262
- * // To mask the payload in logs
263
- * I.sendPatchRequest('/api/users.json', secret({ "email": "user@user.com" }));
264
- *
265
- * ```
266
- *
267
- * @param {string} url
268
- * @param {*} [payload={}] - the payload to be sent. By default it is sent as an empty object
269
- * @param {object} [headers={}] - the headers object to be sent. By default it is sent as an empty object
270
- *
271
- * @returns {Promise<*>} response
272
- */
273
- async sendPatchRequest(url, payload = {}, headers = {}) {
274
- const request = {
275
- baseURL: this._url(url),
276
- method: 'PATCH',
277
- data: payload,
278
- headers,
279
- };
280
-
281
- if (this.options.maxContentLength) {
282
- request.maxContentLength = this.options.maxContentLength;
283
- request.maxBodyLength = this.options.maxBodyLength;
284
- }
285
-
286
- return this._executeRequest(request);
287
- }
288
-
289
- /**
290
- * Sends PUT request to API.
291
- *
292
- * ```js
293
- * I.sendPutRequest('/api/users.json', { "email": "user@user.com" });
294
- *
295
- * // To mask the payload in logs
296
- * I.sendPutRequest('/api/users.json', secret({ "email": "user@user.com" }));
297
- *
298
- * ```
299
- *
300
- * @param {string} url
301
- * @param {*} [payload={}] - the payload to be sent. By default it is sent as an empty object
302
- * @param {object} [headers={}] - the headers object to be sent. By default it is sent as an empty object
303
- *
304
- * @returns {Promise<*>} response
305
- */
306
- async sendPutRequest(url, payload = {}, headers = {}) {
307
- const request = {
308
- baseURL: this._url(url),
309
- method: 'PUT',
310
- data: payload,
311
- headers,
312
- };
313
-
314
- if (this.options.maxContentLength) {
315
- request.maxContentLength = this.options.maxContentLength;
316
- request.maxBodyLength = this.options.maxBodyLength;
317
- }
318
-
319
- return this._executeRequest(request);
320
- }
321
-
322
- /**
323
- * Sends DELETE request to API.
324
- *
325
- * ```js
326
- * I.sendDeleteRequest('/api/users/1');
327
- * ```
328
- *
329
- * @param {*} url
330
- * @param {object} [headers={}] - the headers object to be sent. By default, it is sent as an empty object
331
- *
332
- * @returns {Promise<*>} response
333
- */
334
- async sendDeleteRequest(url, headers = {}) {
335
- const request = {
336
- baseURL: this._url(url),
337
- method: 'DELETE',
338
- headers,
339
- };
340
-
341
- return this._executeRequest(request);
342
- }
343
- }
344
- module.exports = REST;