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

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 (129) 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/plugin/coverage.js +112 -99
  28. package/lib/step.js +3 -1
  29. package/package.json +48 -37
  30. package/typings/index.d.ts +19 -2
  31. package/typings/promiseBasedTypes.d.ts +505 -41
  32. package/typings/types.d.ts +609 -56
  33. package/docs/advanced.md +0 -351
  34. package/docs/ai.md +0 -365
  35. package/docs/api.md +0 -323
  36. package/docs/basics.md +0 -979
  37. package/docs/bdd.md +0 -539
  38. package/docs/best.md +0 -237
  39. package/docs/books.md +0 -37
  40. package/docs/bootstrap.md +0 -135
  41. package/docs/build/AI.js +0 -124
  42. package/docs/build/ApiDataFactory.js +0 -410
  43. package/docs/build/Appium.js +0 -2027
  44. package/docs/build/Expect.js +0 -422
  45. package/docs/build/FileSystem.js +0 -228
  46. package/docs/build/GraphQL.js +0 -229
  47. package/docs/build/GraphQLDataFactory.js +0 -309
  48. package/docs/build/JSONResponse.js +0 -338
  49. package/docs/build/Mochawesome.js +0 -71
  50. package/docs/build/Nightmare.js +0 -2152
  51. package/docs/build/OpenAI.js +0 -126
  52. package/docs/build/Playwright.js +0 -5110
  53. package/docs/build/Protractor.js +0 -2706
  54. package/docs/build/Puppeteer.js +0 -3905
  55. package/docs/build/REST.js +0 -344
  56. package/docs/build/TestCafe.js +0 -2125
  57. package/docs/build/WebDriver.js +0 -4240
  58. package/docs/changelog.md +0 -2572
  59. package/docs/commands.md +0 -266
  60. package/docs/community-helpers.md +0 -58
  61. package/docs/configuration.md +0 -157
  62. package/docs/continuous-integration.md +0 -22
  63. package/docs/custom-helpers.md +0 -306
  64. package/docs/data.md +0 -379
  65. package/docs/detox.md +0 -235
  66. package/docs/docker.md +0 -136
  67. package/docs/email.md +0 -183
  68. package/docs/examples.md +0 -149
  69. package/docs/heal.md +0 -186
  70. package/docs/helpers/ApiDataFactory.md +0 -266
  71. package/docs/helpers/Appium.md +0 -1374
  72. package/docs/helpers/Detox.md +0 -586
  73. package/docs/helpers/Expect.md +0 -275
  74. package/docs/helpers/FileSystem.md +0 -152
  75. package/docs/helpers/GraphQL.md +0 -151
  76. package/docs/helpers/GraphQLDataFactory.md +0 -226
  77. package/docs/helpers/JSONResponse.md +0 -254
  78. package/docs/helpers/Mochawesome.md +0 -8
  79. package/docs/helpers/MockRequest.md +0 -377
  80. package/docs/helpers/Nightmare.md +0 -1305
  81. package/docs/helpers/OpenAI.md +0 -70
  82. package/docs/helpers/Playwright.md +0 -2759
  83. package/docs/helpers/Polly.md +0 -44
  84. package/docs/helpers/Protractor.md +0 -1769
  85. package/docs/helpers/Puppeteer-firefox.md +0 -86
  86. package/docs/helpers/Puppeteer.md +0 -2317
  87. package/docs/helpers/REST.md +0 -218
  88. package/docs/helpers/TestCafe.md +0 -1321
  89. package/docs/helpers/WebDriver.md +0 -2547
  90. package/docs/hooks.md +0 -340
  91. package/docs/index.md +0 -111
  92. package/docs/installation.md +0 -75
  93. package/docs/internal-api.md +0 -266
  94. package/docs/locators.md +0 -339
  95. package/docs/mobile-react-native-locators.md +0 -67
  96. package/docs/mobile.md +0 -338
  97. package/docs/pageobjects.md +0 -291
  98. package/docs/parallel.md +0 -400
  99. package/docs/playwright.md +0 -632
  100. package/docs/plugins.md +0 -1247
  101. package/docs/puppeteer.md +0 -316
  102. package/docs/quickstart.md +0 -162
  103. package/docs/react.md +0 -70
  104. package/docs/reports.md +0 -392
  105. package/docs/secrets.md +0 -36
  106. package/docs/shadow.md +0 -68
  107. package/docs/shared/keys.mustache +0 -31
  108. package/docs/shared/react.mustache +0 -1
  109. package/docs/testcafe.md +0 -174
  110. package/docs/translation.md +0 -247
  111. package/docs/tutorial.md +0 -271
  112. package/docs/typescript.md +0 -180
  113. package/docs/ui.md +0 -59
  114. package/docs/videos.md +0 -28
  115. package/docs/visual.md +0 -202
  116. package/docs/vue.md +0 -143
  117. package/docs/webdriver.md +0 -701
  118. package/docs/wiki/Books-&-Posts.md +0 -27
  119. package/docs/wiki/Community-Helpers-&-Plugins.md +0 -53
  120. package/docs/wiki/Converting-Playwright-to-Istanbul-Coverage.md +0 -61
  121. package/docs/wiki/Examples.md +0 -145
  122. package/docs/wiki/Google-Summer-of-Code-(GSoC)-2020.md +0 -68
  123. package/docs/wiki/Home.md +0 -16
  124. package/docs/wiki/Migration-to-Appium-v2---CodeceptJS.md +0 -83
  125. package/docs/wiki/Release-Process.md +0 -24
  126. package/docs/wiki/Roadmap.md +0 -23
  127. package/docs/wiki/Tests.md +0 -1393
  128. package/docs/wiki/Upgrading-to-CodeceptJS-3.md +0 -153
  129. package/docs/wiki/Videos.md +0 -19
@@ -1,422 +0,0 @@
1
- const chai = require('chai');
2
- const output = require('../output');
3
-
4
- const { expect } = chai;
5
-
6
- chai.use(require('chai-string'));
7
- // @ts-ignore
8
- chai.use(require('chai-exclude'));
9
- chai.use(require('chai-match-pattern'));
10
-
11
- /**
12
- * This helper allows performing assertions based on Chai.
13
- *
14
- * ### Examples
15
- *
16
- * Zero-configuration when paired with other helpers like REST, Playwright:
17
- *
18
- * ```js
19
- * // inside codecept.conf.js
20
- *{
21
- * helpers: {
22
- * Playwright: {...},
23
- * Expect: {},
24
- * }
25
- *}
26
- * ```
27
- *
28
- * ## Methods
29
- */
30
- class ExpectHelper {
31
- /**
32
- *
33
- * @param {*} actualValue
34
- * @param {*} expectedValue
35
- * @param {*} [customErrorMsg]
36
- */
37
- expectEqual(actualValue, expectedValue, customErrorMsg = '') {
38
- // @ts-ignore
39
- output.step(`I expect "${JSON.stringify(actualValue)}" to equal "${JSON.stringify(expectedValue)}"`);
40
- return expect(actualValue, customErrorMsg).to.equal(expectedValue);
41
- }
42
-
43
- /**
44
- *
45
- * @param {*} actualValue
46
- * @param {*} expectedValue
47
- * @param {*} [customErrorMsg]
48
- */
49
- expectNotEqual(actualValue, expectedValue, customErrorMsg = '') {
50
- // @ts-ignore
51
- output.step(`I expect "${JSON.stringify(actualValue)}" to not equal "${JSON.stringify(expectedValue)}"`);
52
- return expect(actualValue, customErrorMsg).not.to.equal(expectedValue);
53
- }
54
-
55
- /**
56
- *
57
- * @param {*} actualValue
58
- * @param {*} expectedValue
59
- * @param {*} [customErrorMsg]
60
-
61
- */
62
- expectDeepEqual(actualValue, expectedValue, customErrorMsg = '') {
63
- // @ts-ignore
64
- output.step(`I expect "${JSON.stringify(actualValue)}" to deep equal "${JSON.stringify(expectedValue)}"`);
65
- return expect(actualValue, customErrorMsg).to.deep.equal(expectedValue);
66
- }
67
-
68
- /**
69
- *
70
- * @param {*} actualValue
71
- * @param {*} expectedValue
72
- * @param {*} [customErrorMsg]
73
- */
74
- expectNotDeepEqual(actualValue, expectedValue, customErrorMsg = '') {
75
- // @ts-ignore
76
- output.step(`I expect "${JSON.stringify(actualValue)}" to not deep equal "${JSON.stringify(expectedValue)}"`);
77
- return expect(actualValue, customErrorMsg).to.not.deep.equal(expectedValue);
78
- }
79
-
80
- /**
81
- *
82
- * @param {*} actualValue
83
- * @param {*} expectedValueToContain
84
- * @param {*} [customErrorMsg]
85
- */
86
- expectContain(actualValue, expectedValueToContain, customErrorMsg = '') {
87
- // @ts-ignore
88
- output.step(`I expect "${JSON.stringify(actualValue)}" to contain "${JSON.stringify(expectedValueToContain)}"`);
89
- return expect(actualValue, customErrorMsg).to.contain(
90
- expectedValueToContain,
91
- );
92
- }
93
-
94
- /**
95
- *
96
- * @param {*} actualValue
97
- * @param {*} expectedValueToNotContain
98
- * @param {*} [customErrorMsg]
99
- */
100
- expectNotContain(
101
- actualValue,
102
- expectedValueToNotContain,
103
- customErrorMsg = '',
104
- ) {
105
- // @ts-ignore
106
- output.step(`I expect "${JSON.stringify(actualValue)}" to not contain "${JSON.stringify(expectedValueToNotContain)}"`);
107
- return expect(actualValue, customErrorMsg).not.to.contain(
108
- expectedValueToNotContain,
109
- );
110
- }
111
-
112
- /**
113
- *
114
- * @param {*} actualValue
115
- * @param {*} expectedValueToStartWith
116
- * @param {*} [customErrorMsg]
117
- */
118
- expectStartsWith(actualValue, expectedValueToStartWith, customErrorMsg = '') {
119
- // @ts-ignore
120
- output.step(`I expect "${JSON.stringify(actualValue)}" to start with "${JSON.stringify(expectedValueToStartWith)}"`);
121
- return expect(actualValue, customErrorMsg).to.startsWith(
122
- expectedValueToStartWith,
123
- );
124
- }
125
-
126
- /**
127
- *
128
- * @param {*} actualValue
129
- * @param {*} expectedValueToNotStartWith
130
- * @param {*} [customErrorMsg]
131
- */
132
- expectNotStartsWith(
133
- actualValue,
134
- expectedValueToNotStartWith,
135
- customErrorMsg = '',
136
- ) {
137
- // @ts-ignore
138
- output.step(`I expect "${JSON.stringify(actualValue)}" to not start with "${JSON.stringify(expectedValueToNotStartWith)}"`);
139
- return expect(actualValue, customErrorMsg).not.to.startsWith(
140
- expectedValueToNotStartWith,
141
- );
142
- }
143
-
144
- /**
145
- * @param {*} actualValue
146
- * @param {*} expectedValueToEndWith
147
- * @param {*} [customErrorMsg]
148
- */
149
- expectEndsWith(actualValue, expectedValueToEndWith, customErrorMsg = '') {
150
- // @ts-ignore
151
- output.step(`I expect "${JSON.stringify(actualValue)}" to end with "${JSON.stringify(expectedValueToEndWith)}"`);
152
- return expect(actualValue, customErrorMsg).to.endsWith(
153
- expectedValueToEndWith,
154
- );
155
- }
156
-
157
- /**
158
- * @param {*} actualValue
159
- * @param {*} expectedValueToNotEndWith
160
- * @param {*} [customErrorMsg]
161
- */
162
- expectNotEndsWith(
163
- actualValue,
164
- expectedValueToNotEndWith,
165
- customErrorMsg = '',
166
- ) {
167
- // @ts-ignore
168
- output.step(`I expect "${JSON.stringify(actualValue)}" to not end with "${JSON.stringify(expectedValueToNotEndWith)}"`);
169
- return expect(actualValue, customErrorMsg).not.to.endsWith(
170
- expectedValueToNotEndWith,
171
- );
172
- }
173
-
174
- /**
175
- * @param {*} targetData
176
- * @param {*} jsonSchema
177
- * @param {*} [customErrorMsg]
178
- */
179
- expectJsonSchema(targetData, jsonSchema, customErrorMsg = '') {
180
- // @ts-ignore
181
- output.step(`I expect "${JSON.stringify(targetData)}" to match this JSON schema "${JSON.stringify(jsonSchema)}"`);
182
- chai.use(require('chai-json-schema'));
183
- return expect(targetData, customErrorMsg).to.be.jsonSchema(jsonSchema);
184
- }
185
-
186
- /**
187
- * @param {*} targetData
188
- * @param {*} jsonSchema
189
- * @param {*} [customErrorMsg]
190
- * @param {*} ajvOptions Pass AJV options
191
- */
192
- expectJsonSchemaUsingAJV(
193
- targetData,
194
- jsonSchema,
195
- customErrorMsg = '',
196
- ajvOptions = { allErrors: true },
197
- ) {
198
- // @ts-ignore
199
- output.step(`I expect "${JSON.stringify(targetData)}" to match this JSON schema using AJV "${JSON.stringify(jsonSchema)}"`);
200
- chai.use(require('chai-json-schema-ajv').create(ajvOptions));
201
- return expect(targetData, customErrorMsg).to.be.jsonSchema(jsonSchema);
202
- }
203
-
204
- /**
205
- * @param {*} targetData
206
- * @param {*} propertyName
207
- * @param {*} [customErrorMsg]
208
- */
209
- expectHasProperty(targetData, propertyName, customErrorMsg = '') {
210
- // @ts-ignore
211
- output.step(`I expect "${JSON.stringify(targetData)}" to have property: "${JSON.stringify(propertyName)}"`);
212
- return expect(targetData, customErrorMsg).to.have.property(propertyName);
213
- }
214
-
215
- /**
216
- * @param {*} targetData
217
- * @param {*} propertyName
218
- * @param {*} [customErrorMsg]
219
- */
220
- expectHasAProperty(targetData, propertyName, customErrorMsg = '') {
221
- // @ts-ignore
222
- output.step(`I expect "${JSON.stringify(targetData)}" to have a property: "${JSON.stringify(propertyName)}"`);
223
- return expect(targetData, customErrorMsg).to.have.a.property(propertyName);
224
- }
225
-
226
- /**
227
- * @param {*} targetData
228
- * @param {*} type
229
- * @param {*} [customErrorMsg]
230
- */
231
- expectToBeA(targetData, type, customErrorMsg = '') {
232
- // @ts-ignore
233
- output.step(`I expect "${JSON.stringify(targetData)}" to be a "${JSON.stringify(type)}"`);
234
- return expect(targetData, customErrorMsg).to.be.a(type);
235
- }
236
-
237
- /**
238
- * @param {*} targetData
239
- * @param {*} type
240
- * @param {*} [customErrorMsg]
241
- */
242
- expectToBeAn(targetData, type, customErrorMsg = '') {
243
- // @ts-ignore
244
- output.step(`I expect "${JSON.stringify(targetData)}" to be an "${JSON.stringify(type)}"`);
245
- return expect(targetData, customErrorMsg).to.be.an(type);
246
- }
247
-
248
- /**
249
- * @param {*} targetData
250
- * @param {*} regex
251
- * @param {*} [customErrorMsg]
252
- */
253
- expectMatchRegex(targetData, regex, customErrorMsg = '') {
254
- // @ts-ignore
255
- output.step(`I expect "${JSON.stringify(targetData)}" to match the regex "${JSON.stringify(regex)}"`);
256
- return expect(targetData, customErrorMsg).to.match(regex);
257
- }
258
-
259
- /**
260
- * @param {*} targetData
261
- * @param {*} length
262
- * @param {*} [customErrorMsg]
263
- */
264
- expectLengthOf(targetData, length, customErrorMsg = '') {
265
- // @ts-ignore
266
- output.step(`I expect "${JSON.stringify(targetData)}" to have length of "${JSON.stringify(length)}"`);
267
- return expect(targetData, customErrorMsg).to.have.lengthOf(length);
268
- }
269
-
270
- /**
271
- * @param {*} targetData
272
- * @param {*} [customErrorMsg]
273
- */
274
- expectEmpty(targetData, customErrorMsg = '') {
275
- // @ts-ignore
276
- output.step(`I expect "${JSON.stringify(targetData)}" to be empty`);
277
- return expect(targetData, customErrorMsg).to.be.empty;
278
- }
279
-
280
- /**
281
- * @param {*} targetData
282
- * @param {*} [customErrorMsg]
283
- */
284
- expectTrue(targetData, customErrorMsg = '') {
285
- // @ts-ignore
286
- output.step(`I expect "${JSON.stringify(targetData)}" to be true`);
287
- return expect(targetData, customErrorMsg).to.be.true;
288
- }
289
-
290
- /**
291
- * @param {*} targetData
292
- * @param {*} [customErrorMsg]
293
- */
294
- expectFalse(targetData, customErrorMsg = '') {
295
- // @ts-ignore
296
- output.step(`I expect "${JSON.stringify(targetData)}" to be false`);
297
- return expect(targetData, customErrorMsg).to.be.false;
298
- }
299
-
300
- /**
301
- * @param {*} targetData
302
- * @param {*} aboveThan
303
- * @param {*} [customErrorMsg]
304
- */
305
- expectAbove(targetData, aboveThan, customErrorMsg = '') {
306
- // @ts-ignore
307
- output.step(`I expect "${JSON.stringify(targetData)}" to be above ${JSON.stringify(aboveThan)}`);
308
- return expect(targetData, customErrorMsg).to.be.above(aboveThan);
309
- }
310
-
311
- /**
312
- * @param {*} targetData
313
- * @param {*} belowThan
314
- * @param {*} [customErrorMsg]
315
- */
316
- expectBelow(targetData, belowThan, customErrorMsg = '') {
317
- // @ts-ignore
318
- output.step(`I expect "${JSON.stringify(targetData)}" to be below ${JSON.stringify(belowThan)}`);
319
- return expect(targetData, customErrorMsg).to.be.below(belowThan);
320
- }
321
-
322
- /**
323
- * @param {*} targetData
324
- * @param {*} lengthAboveThan
325
- * @param {*} [customErrorMsg]
326
- */
327
- expectLengthAboveThan(targetData, lengthAboveThan, customErrorMsg = '') {
328
- // @ts-ignore
329
- output.step(`I expect "${JSON.stringify(targetData)}" to have length of above ${JSON.stringify(lengthAboveThan)}`);
330
- return expect(targetData, customErrorMsg).to.have.lengthOf.above(
331
- lengthAboveThan,
332
- );
333
- }
334
-
335
- /**
336
- * @param {*} targetData
337
- * @param {*} lengthBelowThan
338
- * @param {*} [customErrorMsg]
339
- */
340
- expectLengthBelowThan(targetData, lengthBelowThan, customErrorMsg = '') {
341
- // @ts-ignore
342
- output.step(`I expect "${JSON.stringify(targetData)}" to have length of below ${JSON.stringify(lengthBelowThan)}`);
343
- return expect(targetData, customErrorMsg).to.have.lengthOf.below(
344
- lengthBelowThan,
345
- );
346
- }
347
-
348
- /**
349
- * @param {*} actualValue
350
- * @param {*} expectedValue
351
- * @param {*} [customErrorMsg]
352
- */
353
- expectEqualIgnoreCase(actualValue, expectedValue, customErrorMsg = '') {
354
- // @ts-ignore
355
- output.step(`I expect and ingore case "${JSON.stringify(actualValue)}" to equal "${JSON.stringify(expectedValue)}"`);
356
- return expect(actualValue, customErrorMsg).to.equalIgnoreCase(
357
- expectedValue,
358
- );
359
- }
360
-
361
- /**
362
- * expects members of two arrays are deeply equal
363
- * @param {*} actualValue
364
- * @param {*} expectedValue
365
- * @param {*} [customErrorMsg]
366
- */
367
- expectDeepMembers(actualValue, expectedValue, customErrorMsg = '') {
368
- // @ts-ignore
369
- output.step(`I expect members of "${JSON.stringify(actualValue)}" and "${JSON.stringify(expectedValue)}" arrays are deeply equal`);
370
- return expect(actualValue, customErrorMsg).to.have.deep.members(
371
- expectedValue,
372
- );
373
- }
374
-
375
- /**
376
- * expects an array to be a superset of another array
377
- * @param {*} superset
378
- * @param {*} set
379
- * @param {*} [customErrorMsg]
380
- */
381
- expectDeepIncludeMembers(superset, set, customErrorMsg = '') {
382
- // @ts-ignore
383
- output.step(`I expect "${JSON.stringify(superset)}" array to be a superset of "${JSON.stringify(set)}" array`);
384
- return expect(superset, customErrorMsg).to.deep.include.members(
385
- set,
386
- );
387
- }
388
-
389
- /**
390
- * expects members of two JSON objects are deeply equal excluding some properties
391
- * @param {*} actualValue
392
- * @param {*} expectedValue
393
- * @param {*} fieldsToExclude
394
- * @param {*} [customErrorMsg]
395
- */
396
- expectDeepEqualExcluding(
397
- actualValue,
398
- expectedValue,
399
- fieldsToExclude,
400
- customErrorMsg = '',
401
- ) {
402
- // @ts-ignore
403
- output.step(`I expect members of "${JSON.stringify(actualValue)}" and "${JSON.stringify(expectedValue)}" JSON objects are deeply equal excluding properties: ${JSON.stringify(fieldsToExclude)}`);
404
- return expect(actualValue, customErrorMsg)
405
- .excludingEvery(fieldsToExclude)
406
- .to.deep.equal(expectedValue);
407
- }
408
-
409
- /**
410
- * expects a JSON object matches a provided pattern
411
- * @param {*} actualValue
412
- * @param {*} expectedPattern
413
- * @param {*} [customErrorMsg]
414
- */
415
- expectMatchesPattern(actualValue, expectedPattern, customErrorMsg = '') {
416
- // @ts-ignore
417
- output.step(`I expect "${JSON.stringify(actualValue)}" to match the ${JSON.stringify(expectedPattern)} pattern`);
418
- return expect(actualValue, customErrorMsg).to.matchPattern(expectedPattern);
419
- }
420
- }
421
-
422
- module.exports = ExpectHelper;
@@ -1,228 +0,0 @@
1
- const assert = require('assert');
2
- const path = require('path');
3
- const fs = require('fs');
4
-
5
- const Helper = require('@codeceptjs/helper');
6
- const { fileExists } = require('../utils');
7
- const { fileIncludes } = require('../assert/include');
8
- const { fileEquals } = require('../assert/equal');
9
-
10
- /**
11
- * Helper for testing filesystem.
12
- * Can be easily used to check file structures:
13
- *
14
- * ```js
15
- * I.amInPath('test');
16
- * I.seeFile('codecept.js');
17
- * I.seeInThisFile('FileSystem');
18
- * I.dontSeeInThisFile("WebDriver");
19
- * ```
20
- *
21
- * ## Configuration
22
- *
23
- * Enable helper in config file:
24
- *
25
- * ```js
26
- * helpers: {
27
- * FileSystem: {},
28
- * }
29
- * ```
30
- *
31
- * ## Methods
32
- */
33
- class FileSystem extends Helper {
34
- constructor() {
35
- super();
36
- this.dir = global.codecept_dir;
37
- this.file = '';
38
- }
39
-
40
- _before() {
41
- this.debugSection('Dir', this.dir);
42
- }
43
-
44
- /**
45
- * Enters a directory In local filesystem.
46
- * Starts from a current directory
47
- * @param {string} openPath
48
- */
49
- amInPath(openPath) {
50
- this.dir = path.join(global.codecept_dir, openPath);
51
- this.debugSection('Dir', this.dir);
52
- }
53
-
54
- /**
55
- * Writes text to file
56
- * @param {string} name
57
- * @param {string} text
58
- */
59
- writeToFile(name, text) {
60
- fs.writeFileSync(path.join(this.dir, name), text);
61
- }
62
-
63
- /**
64
- * Checks that file exists
65
- * @param {string} name
66
- */
67
- seeFile(name) {
68
- this.file = path.join(this.dir, name);
69
- this.debugSection('File', this.file);
70
- assert.ok(fileExists(this.file), `File ${name} not found in ${this.dir}`);
71
- }
72
-
73
- /**
74
- * Waits for the file to be present in the current directory.
75
- *
76
- * ```js
77
- * I.handleDownloads('downloads/largeFilesName.txt');
78
- * I.click('Download large File');
79
- * I.amInPath('output/downloads');
80
- * I.waitForFile('largeFilesName.txt', 10); // wait 10 seconds for file
81
- * ```
82
- * @param {string} name
83
- * @param {number} [sec=1] seconds to wait
84
- */
85
- async waitForFile(name, sec = 1) {
86
- if (sec === 0) assert.fail('Use `seeFile` instead of waiting 0 seconds!');
87
- const waitTimeout = sec * 1000;
88
- this.file = path.join(this.dir, name);
89
- this.debugSection('File', this.file);
90
- return isFileExists(this.file, waitTimeout).catch(() => {
91
- throw new Error(`file (${name}) still not present in directory ${this.dir} after ${waitTimeout / 1000} sec`);
92
- });
93
- }
94
-
95
- /**
96
- * Checks that file with a name including given text exists in the current directory.
97
- *
98
- *```js
99
- * I.handleDownloads();
100
- * I.click('Download as PDF');
101
- * I.amInPath('output/downloads');
102
- * I.seeFileNameMatching('.pdf');
103
- * ```
104
- * @param {string} text
105
- */
106
- seeFileNameMatching(text) {
107
- assert.ok(
108
- this.grabFileNames().some(file => file.includes(text)),
109
- `File name which contains ${text} not found in ${this.dir}`,
110
- );
111
- }
112
-
113
- /**
114
- * Checks that file found by `seeFile` includes a text.
115
- * @param {string} text
116
- * @param {string} [encoding='utf8']
117
- */
118
- seeInThisFile(text, encoding = 'utf8') {
119
- const content = getFileContents(this.file, encoding);
120
- fileIncludes(this.file).assert(text, content);
121
- }
122
-
123
- /**
124
- * Checks that file found by `seeFile` doesn't include text.
125
- * @param {string} text
126
- * @param {string} [encoding='utf8']
127
- */
128
- dontSeeInThisFile(text, encoding = 'utf8') {
129
- const content = getFileContents(this.file, encoding);
130
- fileIncludes(this.file).negate(text, content);
131
- }
132
-
133
- /**
134
- * Checks that contents of file found by `seeFile` equal to text.
135
- * @param {string} text
136
- * @param {string} [encoding='utf8']
137
- */
138
- seeFileContentsEqual(text, encoding = 'utf8') {
139
- const content = getFileContents(this.file, encoding);
140
- fileEquals(this.file).assert(text, content);
141
- }
142
-
143
- /**
144
- * Checks that contents of the file found by `seeFile` equal to contents of the file at `pathToReferenceFile`.
145
- * @param {string} pathToReferenceFile
146
- * @param {string} [encoding='utf8']
147
- * @param {string} [encodingReference='utf8']
148
- */
149
- seeFileContentsEqualReferenceFile(pathToReferenceFile, encoding = 'utf8', encodingReference = '') {
150
- const content = getFileContents(this.file, encoding);
151
- assert.ok(fileExists(pathToReferenceFile), `Reference file ${pathToReferenceFile} not found.`);
152
- encodingReference = encodingReference || encoding;
153
- const expectedContent = getFileContents(pathToReferenceFile, encodingReference);
154
- fileEquals(this.file).assert(expectedContent, content);
155
- }
156
-
157
- /**
158
- * Checks that contents of file found by `seeFile` doesn't equal to text.
159
- * @param {string} text
160
- * @param {string} [encoding='utf8']
161
- */
162
- dontSeeFileContentsEqual(text, encoding = 'utf8') {
163
- const content = getFileContents(this.file, encoding);
164
- fileEquals(this.file).negate(text, content);
165
- }
166
-
167
- /**
168
- * Returns file names in current directory.
169
- *
170
- * ```js
171
- * I.handleDownloads();
172
- * I.click('Download Files');
173
- * I.amInPath('output/downloads');
174
- * const downloadedFileNames = I.grabFileNames();
175
- * ```
176
- */
177
- grabFileNames() {
178
- return fs.readdirSync(this.dir)
179
- .filter(item => !fs.lstatSync(path.join(this.dir, item)).isDirectory());
180
- }
181
- }
182
-
183
- module.exports = FileSystem;
184
-
185
- /**
186
- * @param {string} file
187
- * @param {string} [encoding='utf8']
188
- * @private
189
- * @returns {string}
190
- */
191
- function getFileContents(file, encoding = 'utf8') {
192
- if (!file) assert.fail('No files were opened, please use seeFile action');
193
- if (encoding === '') assert.fail('Encoding is an empty string, please set a valid encoding');
194
- return fs.readFileSync(file, encoding);
195
- }
196
-
197
- /**
198
- * @param {string} file
199
- * @param {number} timeout
200
- * @private
201
- * @returns {Promise<any>}
202
- */
203
- function isFileExists(file, timeout) {
204
- return new Promise(((resolve, reject) => {
205
- const timer = setTimeout(() => {
206
- watcher.close();
207
- reject(new Error('File did not exists and was not created during the timeout.'));
208
- }, timeout);
209
-
210
- const dir = path.dirname(file);
211
- const basename = path.basename(file);
212
- const watcher = fs.watch(dir, (eventType, filename) => {
213
- if (eventType === 'rename' && filename === basename) {
214
- clearTimeout(timer);
215
- watcher.close();
216
- resolve();
217
- }
218
- });
219
-
220
- fs.access(file, fs.constants.R_OK, (err) => {
221
- if (!err) {
222
- clearTimeout(timer);
223
- watcher.close();
224
- resolve();
225
- }
226
- });
227
- }));
228
- }