codeceptjs 3.5.12-beta.5 → 3.5.12-beta.6

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 (214) hide show
  1. package/lib/helper/Playwright.js +41 -22
  2. package/lib/helper/Puppeteer.js +23 -6
  3. package/lib/helper/WebDriver.js +23 -4
  4. package/lib/helper/errors/ElementAssertion.js +38 -0
  5. package/lib/locator.js +4 -13
  6. package/package.json +8 -10
  7. package/docs/advanced.md +0 -351
  8. package/docs/ai.md +0 -248
  9. package/docs/api.md +0 -323
  10. package/docs/basics.md +0 -979
  11. package/docs/bdd.md +0 -539
  12. package/docs/best.md +0 -237
  13. package/docs/books.md +0 -37
  14. package/docs/bootstrap.md +0 -135
  15. package/docs/build/ApiDataFactory.js +0 -410
  16. package/docs/build/Appium.js +0 -2027
  17. package/docs/build/Expect.js +0 -422
  18. package/docs/build/FileSystem.js +0 -228
  19. package/docs/build/GraphQL.js +0 -229
  20. package/docs/build/GraphQLDataFactory.js +0 -309
  21. package/docs/build/JSONResponse.js +0 -338
  22. package/docs/build/Mochawesome.js +0 -71
  23. package/docs/build/Nightmare.js +0 -2152
  24. package/docs/build/OpenAI.js +0 -126
  25. package/docs/build/Playwright.js +0 -5110
  26. package/docs/build/Protractor.js +0 -2706
  27. package/docs/build/Puppeteer.js +0 -3905
  28. package/docs/build/REST.js +0 -344
  29. package/docs/build/TestCafe.js +0 -2125
  30. package/docs/build/WebDriver.js +0 -4240
  31. package/docs/changelog.md +0 -2572
  32. package/docs/commands.md +0 -266
  33. package/docs/community-helpers.md +0 -58
  34. package/docs/configuration.md +0 -157
  35. package/docs/continuous-integration.md +0 -22
  36. package/docs/custom-helpers.md +0 -306
  37. package/docs/data.md +0 -379
  38. package/docs/detox.md +0 -235
  39. package/docs/docker.md +0 -136
  40. package/docs/email.md +0 -183
  41. package/docs/examples.md +0 -149
  42. package/docs/helpers/ApiDataFactory.md +0 -266
  43. package/docs/helpers/Appium.md +0 -1374
  44. package/docs/helpers/Detox.md +0 -586
  45. package/docs/helpers/Expect.md +0 -275
  46. package/docs/helpers/FileSystem.md +0 -152
  47. package/docs/helpers/GraphQL.md +0 -151
  48. package/docs/helpers/GraphQLDataFactory.md +0 -226
  49. package/docs/helpers/JSONResponse.md +0 -254
  50. package/docs/helpers/Mochawesome.md +0 -8
  51. package/docs/helpers/MockRequest.md +0 -377
  52. package/docs/helpers/Nightmare.md +0 -1305
  53. package/docs/helpers/OpenAI.md +0 -70
  54. package/docs/helpers/Playwright.md +0 -2759
  55. package/docs/helpers/Polly.md +0 -44
  56. package/docs/helpers/Protractor.md +0 -1769
  57. package/docs/helpers/Puppeteer-firefox.md +0 -86
  58. package/docs/helpers/Puppeteer.md +0 -2317
  59. package/docs/helpers/REST.md +0 -218
  60. package/docs/helpers/TestCafe.md +0 -1321
  61. package/docs/helpers/WebDriver.md +0 -2547
  62. package/docs/hooks.md +0 -340
  63. package/docs/index.md +0 -111
  64. package/docs/installation.md +0 -75
  65. package/docs/internal-api.md +0 -266
  66. package/docs/locators.md +0 -339
  67. package/docs/mobile-react-native-locators.md +0 -67
  68. package/docs/mobile.md +0 -338
  69. package/docs/pageobjects.md +0 -291
  70. package/docs/parallel.md +0 -400
  71. package/docs/playwright.md +0 -632
  72. package/docs/plugins.md +0 -1259
  73. package/docs/puppeteer.md +0 -316
  74. package/docs/quickstart.md +0 -162
  75. package/docs/react.md +0 -70
  76. package/docs/reports.md +0 -392
  77. package/docs/secrets.md +0 -36
  78. package/docs/shadow.md +0 -68
  79. package/docs/shared/keys.mustache +0 -31
  80. package/docs/shared/react.mustache +0 -1
  81. package/docs/testcafe.md +0 -174
  82. package/docs/translation.md +0 -247
  83. package/docs/tutorial.md +0 -271
  84. package/docs/typescript.md +0 -180
  85. package/docs/ui.md +0 -59
  86. package/docs/videos.md +0 -28
  87. package/docs/visual.md +0 -202
  88. package/docs/vue.md +0 -143
  89. package/docs/webapi/amOnPage.mustache +0 -11
  90. package/docs/webapi/appendField.mustache +0 -11
  91. package/docs/webapi/attachFile.mustache +0 -12
  92. package/docs/webapi/blur.mustache +0 -18
  93. package/docs/webapi/checkOption.mustache +0 -13
  94. package/docs/webapi/clearCookie.mustache +0 -9
  95. package/docs/webapi/clearField.mustache +0 -9
  96. package/docs/webapi/click.mustache +0 -25
  97. package/docs/webapi/clickLink.mustache +0 -8
  98. package/docs/webapi/closeCurrentTab.mustache +0 -7
  99. package/docs/webapi/closeOtherTabs.mustache +0 -8
  100. package/docs/webapi/dontSee.mustache +0 -11
  101. package/docs/webapi/dontSeeCheckboxIsChecked.mustache +0 -10
  102. package/docs/webapi/dontSeeCookie.mustache +0 -8
  103. package/docs/webapi/dontSeeCurrentUrlEquals.mustache +0 -10
  104. package/docs/webapi/dontSeeElement.mustache +0 -8
  105. package/docs/webapi/dontSeeElementInDOM.mustache +0 -8
  106. package/docs/webapi/dontSeeInCurrentUrl.mustache +0 -4
  107. package/docs/webapi/dontSeeInField.mustache +0 -11
  108. package/docs/webapi/dontSeeInSource.mustache +0 -8
  109. package/docs/webapi/dontSeeInTitle.mustache +0 -8
  110. package/docs/webapi/doubleClick.mustache +0 -13
  111. package/docs/webapi/downloadFile.mustache +0 -12
  112. package/docs/webapi/dragAndDrop.mustache +0 -9
  113. package/docs/webapi/dragSlider.mustache +0 -11
  114. package/docs/webapi/executeAsyncScript.mustache +0 -24
  115. package/docs/webapi/executeScript.mustache +0 -26
  116. package/docs/webapi/fillField.mustache +0 -16
  117. package/docs/webapi/focus.mustache +0 -13
  118. package/docs/webapi/forceClick.mustache +0 -28
  119. package/docs/webapi/forceRightClick.mustache +0 -18
  120. package/docs/webapi/grabAllWindowHandles.mustache +0 -7
  121. package/docs/webapi/grabAttributeFrom.mustache +0 -10
  122. package/docs/webapi/grabAttributeFromAll.mustache +0 -9
  123. package/docs/webapi/grabBrowserLogs.mustache +0 -9
  124. package/docs/webapi/grabCookie.mustache +0 -11
  125. package/docs/webapi/grabCssPropertyFrom.mustache +0 -11
  126. package/docs/webapi/grabCssPropertyFromAll.mustache +0 -10
  127. package/docs/webapi/grabCurrentUrl.mustache +0 -9
  128. package/docs/webapi/grabCurrentWindowHandle.mustache +0 -6
  129. package/docs/webapi/grabDataFromPerformanceTiming.mustache +0 -20
  130. package/docs/webapi/grabElementBoundingRect.mustache +0 -20
  131. package/docs/webapi/grabGeoLocation.mustache +0 -8
  132. package/docs/webapi/grabHTMLFrom.mustache +0 -10
  133. package/docs/webapi/grabHTMLFromAll.mustache +0 -9
  134. package/docs/webapi/grabNumberOfOpenTabs.mustache +0 -8
  135. package/docs/webapi/grabNumberOfVisibleElements.mustache +0 -9
  136. package/docs/webapi/grabPageScrollPosition.mustache +0 -8
  137. package/docs/webapi/grabPopupText.mustache +0 -5
  138. package/docs/webapi/grabSource.mustache +0 -8
  139. package/docs/webapi/grabTextFrom.mustache +0 -10
  140. package/docs/webapi/grabTextFromAll.mustache +0 -9
  141. package/docs/webapi/grabTitle.mustache +0 -8
  142. package/docs/webapi/grabValueFrom.mustache +0 -9
  143. package/docs/webapi/grabValueFromAll.mustache +0 -8
  144. package/docs/webapi/grabWebElement.mustache +0 -9
  145. package/docs/webapi/grabWebElements.mustache +0 -9
  146. package/docs/webapi/moveCursorTo.mustache +0 -12
  147. package/docs/webapi/openNewTab.mustache +0 -7
  148. package/docs/webapi/pressKey.mustache +0 -12
  149. package/docs/webapi/pressKeyDown.mustache +0 -12
  150. package/docs/webapi/pressKeyUp.mustache +0 -12
  151. package/docs/webapi/pressKeyWithKeyNormalization.mustache +0 -60
  152. package/docs/webapi/refreshPage.mustache +0 -6
  153. package/docs/webapi/resizeWindow.mustache +0 -6
  154. package/docs/webapi/rightClick.mustache +0 -14
  155. package/docs/webapi/saveElementScreenshot.mustache +0 -10
  156. package/docs/webapi/saveScreenshot.mustache +0 -12
  157. package/docs/webapi/say.mustache +0 -10
  158. package/docs/webapi/scrollIntoView.mustache +0 -11
  159. package/docs/webapi/scrollPageToBottom.mustache +0 -6
  160. package/docs/webapi/scrollPageToTop.mustache +0 -6
  161. package/docs/webapi/scrollTo.mustache +0 -12
  162. package/docs/webapi/see.mustache +0 -11
  163. package/docs/webapi/seeAttributesOnElements.mustache +0 -9
  164. package/docs/webapi/seeCheckboxIsChecked.mustache +0 -10
  165. package/docs/webapi/seeCookie.mustache +0 -8
  166. package/docs/webapi/seeCssPropertiesOnElements.mustache +0 -9
  167. package/docs/webapi/seeCurrentUrlEquals.mustache +0 -11
  168. package/docs/webapi/seeElement.mustache +0 -8
  169. package/docs/webapi/seeElementInDOM.mustache +0 -8
  170. package/docs/webapi/seeInCurrentUrl.mustache +0 -8
  171. package/docs/webapi/seeInField.mustache +0 -12
  172. package/docs/webapi/seeInPopup.mustache +0 -8
  173. package/docs/webapi/seeInSource.mustache +0 -7
  174. package/docs/webapi/seeInTitle.mustache +0 -8
  175. package/docs/webapi/seeNumberOfElements.mustache +0 -11
  176. package/docs/webapi/seeNumberOfVisibleElements.mustache +0 -10
  177. package/docs/webapi/seeTextEquals.mustache +0 -9
  178. package/docs/webapi/seeTitleEquals.mustache +0 -8
  179. package/docs/webapi/selectOption.mustache +0 -21
  180. package/docs/webapi/setCookie.mustache +0 -16
  181. package/docs/webapi/setGeoLocation.mustache +0 -12
  182. package/docs/webapi/switchTo.mustache +0 -9
  183. package/docs/webapi/switchToNextTab.mustache +0 -10
  184. package/docs/webapi/switchToPreviousTab.mustache +0 -10
  185. package/docs/webapi/type.mustache +0 -21
  186. package/docs/webapi/uncheckOption.mustache +0 -13
  187. package/docs/webapi/wait.mustache +0 -8
  188. package/docs/webapi/waitForClickable.mustache +0 -11
  189. package/docs/webapi/waitForDetached.mustache +0 -10
  190. package/docs/webapi/waitForElement.mustache +0 -11
  191. package/docs/webapi/waitForEnabled.mustache +0 -6
  192. package/docs/webapi/waitForFunction.mustache +0 -17
  193. package/docs/webapi/waitForInvisible.mustache +0 -10
  194. package/docs/webapi/waitForNumberOfTabs.mustache +0 -9
  195. package/docs/webapi/waitForText.mustache +0 -13
  196. package/docs/webapi/waitForValue.mustache +0 -10
  197. package/docs/webapi/waitForVisible.mustache +0 -10
  198. package/docs/webapi/waitInUrl.mustache +0 -9
  199. package/docs/webapi/waitNumberOfVisibleElements.mustache +0 -10
  200. package/docs/webapi/waitToHide.mustache +0 -10
  201. package/docs/webapi/waitUrlEquals.mustache +0 -10
  202. package/docs/webdriver.md +0 -701
  203. package/docs/wiki/Books-&-Posts.md +0 -27
  204. package/docs/wiki/Community-Helpers-&-Plugins.md +0 -53
  205. package/docs/wiki/Converting-Playwright-to-Istanbul-Coverage.md +0 -61
  206. package/docs/wiki/Examples.md +0 -145
  207. package/docs/wiki/Google-Summer-of-Code-(GSoC)-2020.md +0 -68
  208. package/docs/wiki/Home.md +0 -16
  209. package/docs/wiki/Migration-to-Appium-v2---CodeceptJS.md +0 -83
  210. package/docs/wiki/Release-Process.md +0 -24
  211. package/docs/wiki/Roadmap.md +0 -23
  212. package/docs/wiki/Tests.md +0 -1393
  213. package/docs/wiki/Upgrading-to-CodeceptJS-3.md +0 -153
  214. package/docs/wiki/Videos.md +0 -19
@@ -1,266 +0,0 @@
1
- ---
2
- permalink: /helpers/ApiDataFactory
3
- editLink: false
4
- sidebar: auto
5
- title: ApiDataFactory
6
- ---
7
-
8
- <!-- Generated by documentation.js. Update this documentation by updating the source code. -->
9
-
10
- ## ApiDataFactory
11
-
12
- **Extends Helper**
13
-
14
- Helper for managing remote data using REST API.
15
- Uses data generators like [rosie][1] or factory girl to create new record.
16
-
17
- By defining a factory you set the rules of how data is generated.
18
- This data will be saved on server via REST API and deleted in the end of a test.
19
-
20
- ## Use Case
21
-
22
- Acceptance tests interact with a websites using UI and real browser.
23
- There is no way to create data for a specific test other than from user interface.
24
- That makes tests slow and fragile. Instead of testing a single feature you need to follow all creation/removal process.
25
-
26
- This helper solves this problem.
27
- Most of web application have API, and it can be used to create and delete test records.
28
- By combining REST API with Factories you can easily create records for tests:
29
-
30
- ```js
31
- I.have('user', { login: 'davert', email: 'davert@mail.com' });
32
- let id = await I.have('post', { title: 'My first post'});
33
- I.haveMultiple('comment', 3, {post_id: id});
34
- ```
35
-
36
- To make this work you need
37
-
38
- 1. REST API endpoint which allows to perform create / delete requests and
39
- 2. define data generation rules
40
-
41
- ### Setup
42
-
43
- Install [Rosie][1] and [Faker][2] libraries.
44
-
45
- ```sh
46
- npm i rosie @faker-js/faker --save-dev
47
- ```
48
-
49
- Create a factory file for a resource.
50
-
51
- See the example for Posts factories:
52
-
53
- ```js
54
- // tests/factories/posts.js
55
-
56
- const { Factory } = require('rosie');
57
- const { faker } = require('@faker-js/faker');
58
-
59
- module.exports = new Factory()
60
- // no need to set id, it will be set by REST API
61
- .attr('author', () => faker.name.findName())
62
- .attr('title', () => faker.lorem.sentence())
63
- .attr('body', () => faker.lorem.paragraph());
64
- ```
65
-
66
- For more options see [rosie documentation][1].
67
-
68
- Then configure ApiDataHelper to match factories and REST API:
69
-
70
- ### Configuration
71
-
72
- ApiDataFactory has following config options:
73
-
74
- - `endpoint`: base URL for the API to send requests to.
75
- - `cleanup` (default: true): should inserted records be deleted up after tests
76
- - `factories`: list of defined factories
77
- - `returnId` (default: false): return id instead of a complete response when creating items.
78
- - `headers`: list of headers
79
- - `REST`: configuration for REST requests
80
-
81
- See the example:
82
-
83
- ```js
84
- ApiDataFactory: {
85
- endpoint: "http://user.com/api",
86
- cleanup: true,
87
- headers: {
88
- 'Content-Type': 'application/json',
89
- 'Accept': 'application/json',
90
- },
91
- factories: {
92
- post: {
93
- uri: "/posts",
94
- factory: "./factories/post",
95
- },
96
- comment: {
97
- factory: "./factories/comment",
98
- create: { post: "/comments/create" },
99
- delete: { post: "/comments/delete/{id}" },
100
- fetchId: (data) => data.result.id
101
- }
102
- }
103
- }
104
- ```
105
-
106
- It is required to set REST API `endpoint` which is the baseURL for all API requests.
107
- Factory file is expected to be passed via `factory` option.
108
-
109
- This Helper uses [REST][3] helper and accepts its configuration in "REST" section.
110
- For instance, to set timeout you should add:
111
-
112
- ```js
113
- "ApiDataFactory": {
114
- "REST": {
115
- "timeout": "100000",
116
- }
117
- }
118
- ```
119
-
120
- ### Requests
121
-
122
- By default to create a record ApiDataFactory will use endpoint and plural factory name:
123
-
124
- - create: `POST {endpoint}/{resource} data`
125
- - delete: `DELETE {endpoint}/{resource}/id`
126
-
127
- Example (`endpoint`: `http://app.com/api`):
128
-
129
- - create: POST request to `http://app.com/api/users`
130
- - delete: DELETE request to `http://app.com/api/users/1`
131
-
132
- This behavior can be configured with following options:
133
-
134
- - `uri`: set different resource uri. Example: `uri: account` => `http://app.com/api/account`.
135
- - `create`: override create options. Expected format: `{ method: uri }`. Example: `{ "post": "/users/create" }`
136
- - `delete`: override delete options. Expected format: `{ method: uri }`. Example: `{ "post": "/users/delete/{id}" }`
137
-
138
- Requests can also be overridden with a function which returns [axois request config][4].
139
-
140
- ```js
141
- create: (data) => ({ method: 'post', url: '/posts', data }),
142
- delete: (id) => ({ method: 'delete', url: '/posts', data: { id } })
143
- ```
144
-
145
- Requests can be updated on the fly by using `onRequest` function. For instance, you can pass in current session from a cookie.
146
-
147
- ```js
148
- onRequest: async (request) => {
149
- // using global codeceptjs instance
150
- let cookie = await codeceptjs.container.helpers('WebDriver').grabCookie('session');
151
- request.headers = { Cookie: `session=${cookie.value}` };
152
- }
153
- ```
154
-
155
- ### Responses
156
-
157
- By default `I.have()` returns a promise with a created data:
158
-
159
- ```js
160
- let client = await I.have('client');
161
- ```
162
-
163
- Ids of created records are collected and used in the end of a test for the cleanup.
164
- If you need to receive `id` instead of full response enable `returnId` in a helper config:
165
-
166
- ```js
167
- // returnId: false
168
- let clientId = await I.have('client');
169
- // clientId == 1
170
-
171
- // returnId: true
172
- let clientId = await I.have('client');
173
- // client == { name: 'John', email: 'john@snow.com' }
174
- ```
175
-
176
- By default `id` property of response is taken. This behavior can be changed by setting `fetchId` function in a factory config.
177
-
178
- ```js
179
- factories: {
180
- post: {
181
- uri: "/posts",
182
- factory: "./factories/post",
183
- fetchId: (data) => data.result.posts[0].id
184
- }
185
- }
186
- ```
187
-
188
- ## Methods
189
-
190
- ### Parameters
191
-
192
- - `config`
193
-
194
- ### _requestCreate
195
-
196
- Executes request to create a record in API.
197
- Can be replaced from a in custom helper.
198
-
199
- #### Parameters
200
-
201
- - `factory` **any**
202
- - `data` **any**
203
-
204
- ### _requestDelete
205
-
206
- Executes request to delete a record in API
207
- Can be replaced from a custom helper.
208
-
209
- #### Parameters
210
-
211
- - `factory` **any**
212
- - `id` **any**
213
-
214
- ### have
215
-
216
- Generates a new record using factory and saves API request to store it.
217
-
218
- ```js
219
- // create a user
220
- I.have('user');
221
- // create user with defined email
222
- // and receive it when inside async function
223
- const user = await I.have('user', { email: 'user@user.com'});
224
- // create a user with options that will not be included in the final request
225
- I.have('user', { }, { age: 33, height: 55 })
226
- ```
227
-
228
- #### Parameters
229
-
230
- - `factory` **any** factory to use
231
- - `params` **any?** predefined parameters
232
- - `options` **any?** options for programmatically generate the attributes
233
-
234
- Returns **[Promise][5]&lt;any>**
235
-
236
- ### haveMultiple
237
-
238
- Generates bunch of records and saves multiple API requests to store them.
239
-
240
- ```js
241
- // create 3 posts
242
- I.haveMultiple('post', 3);
243
-
244
- // create 3 posts by one author
245
- I.haveMultiple('post', 3, { author: 'davert' });
246
-
247
- // create 3 posts by one author with options
248
- I.haveMultiple('post', 3, { author: 'davert' }, { publish_date: '01.01.1997' });
249
- ```
250
-
251
- #### Parameters
252
-
253
- - `factory` **any**
254
- - `times` **any**
255
- - `params` **any?**
256
- - `options` **any?**
257
-
258
- [1]: https://github.com/rosiejs/rosie
259
-
260
- [2]: https://www.npmjs.com/package/faker
261
-
262
- [3]: http://codecept.io/helpers/REST/
263
-
264
- [4]: https://github.com/axios/axios#request-config
265
-
266
- [5]: https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Promise