artes 1.2.14 → 1.2.16

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 (38) hide show
  1. package/README.md +533 -533
  2. package/cucumber.config.js +171 -171
  3. package/docs/functionDefinitions.md +2401 -2401
  4. package/docs/stepDefinitions.md +352 -352
  5. package/executer.js +161 -161
  6. package/index.js +48 -48
  7. package/package.json +51 -54
  8. package/src/helper/contextManager/browserManager.js +63 -63
  9. package/src/helper/contextManager/requestManager.js +23 -23
  10. package/src/helper/controller/elementController.js +182 -182
  11. package/src/helper/controller/pomCollector.js +25 -25
  12. package/src/helper/executers/cleaner.js +19 -19
  13. package/src/helper/executers/exporter.js +15 -15
  14. package/src/helper/executers/helper.js +95 -95
  15. package/src/helper/executers/projectCreator.js +198 -198
  16. package/src/helper/executers/reportGenerator.js +58 -57
  17. package/src/helper/executers/testRunner.js +30 -30
  18. package/src/helper/executers/versionChecker.js +31 -31
  19. package/src/helper/imports/commons.js +56 -56
  20. package/src/helper/stepFunctions/APIActions.js +362 -362
  21. package/src/helper/stepFunctions/assertions.js +523 -523
  22. package/src/helper/stepFunctions/browserActions.js +22 -22
  23. package/src/helper/stepFunctions/elementInteractions.js +38 -38
  24. package/src/helper/stepFunctions/exporter.js +19 -19
  25. package/src/helper/stepFunctions/frameActions.js +50 -50
  26. package/src/helper/stepFunctions/keyboardActions.js +41 -41
  27. package/src/helper/stepFunctions/mouseActions.js +145 -145
  28. package/src/helper/stepFunctions/pageActions.js +27 -27
  29. package/src/hooks/context.js +15 -15
  30. package/src/hooks/hooks.js +257 -257
  31. package/src/stepDefinitions/API.steps.js +299 -299
  32. package/src/stepDefinitions/assertions.steps.js +861 -861
  33. package/src/stepDefinitions/browser.steps.js +7 -7
  34. package/src/stepDefinitions/frameActions.steps.js +76 -76
  35. package/src/stepDefinitions/keyboardActions.steps.js +226 -226
  36. package/src/stepDefinitions/mouseActions.steps.js +275 -275
  37. package/src/stepDefinitions/page.steps.js +71 -71
  38. package/src/stepDefinitions/random.steps.js +158 -158
@@ -1,22 +1,22 @@
1
- const { context, selector, resolveVariable } = require("../imports/commons");
2
-
3
- const browser = {
4
- setCookies: async (cookies) => {
5
- cookies = await resolveVariable(cookies);
6
-
7
- let cookieData;
8
- try {
9
- cookieData = JSON.parse(cookies);
10
- } catch {
11
- cookieData = selector(cookies);
12
- }
13
-
14
- cookieData = Array.isArray(cookieData) ? cookieData : [cookieData];
15
-
16
- await context.browserContext.addCookies(cookieData);
17
- },
18
- };
19
-
20
- module.exports = {
21
- browser,
22
- };
1
+ const { context, selector, resolveVariable } = require("../imports/commons");
2
+
3
+ const browser = {
4
+ setCookies: async (cookies) => {
5
+ cookies = await resolveVariable(cookies);
6
+
7
+ let cookieData;
8
+ try {
9
+ cookieData = JSON.parse(cookies);
10
+ } catch {
11
+ cookieData = selector(cookies);
12
+ }
13
+
14
+ cookieData = Array.isArray(cookieData) ? cookieData : [cookieData];
15
+
16
+ await context.browserContext.addCookies(cookieData);
17
+ },
18
+ };
19
+
20
+ module.exports = {
21
+ browser,
22
+ };
@@ -1,38 +1,38 @@
1
- const { element } = require("../imports/commons");
2
-
3
- const elementInteractions = {
4
- isChecked: async (selector) => {
5
- return await element(selector).isChecked();
6
- },
7
- isDisabled: async (selector) => {
8
- return await element(selector).isDisabled();
9
- },
10
- isEditable: async (selector) => {
11
- return await element(selector).isEditable();
12
- },
13
- isEnabled: async (selector) => {
14
- return await element(selector).isEnabled();
15
- },
16
- isHidden: async (selector) => {
17
- return await element(selector).isHidden();
18
- },
19
- isVisible: async (selector) => {
20
- return await element(selector).isVisible();
21
- },
22
- getAttribute: async (selector, attribute) => {
23
- return await element(selector).getAttribute(attribute);
24
- },
25
- innerHTML: async (selector) => {
26
- return await element(selector).innerHTML();
27
- },
28
- innerText: async (selector) => {
29
- return await element(selector).innerText();
30
- },
31
- textContent: async (selector) => {
32
- return await element(selector).textContent();
33
- },
34
- };
35
-
36
- module.exports = {
37
- elementInteractions,
38
- };
1
+ const { element } = require("../imports/commons");
2
+
3
+ const elementInteractions = {
4
+ isChecked: async (selector) => {
5
+ return await element(selector).isChecked();
6
+ },
7
+ isDisabled: async (selector) => {
8
+ return await element(selector).isDisabled();
9
+ },
10
+ isEditable: async (selector) => {
11
+ return await element(selector).isEditable();
12
+ },
13
+ isEnabled: async (selector) => {
14
+ return await element(selector).isEnabled();
15
+ },
16
+ isHidden: async (selector) => {
17
+ return await element(selector).isHidden();
18
+ },
19
+ isVisible: async (selector) => {
20
+ return await element(selector).isVisible();
21
+ },
22
+ getAttribute: async (selector, attribute) => {
23
+ return await element(selector).getAttribute(attribute);
24
+ },
25
+ innerHTML: async (selector) => {
26
+ return await element(selector).innerHTML();
27
+ },
28
+ innerText: async (selector) => {
29
+ return await element(selector).innerText();
30
+ },
31
+ textContent: async (selector) => {
32
+ return await element(selector).textContent();
33
+ },
34
+ };
35
+
36
+ module.exports = {
37
+ elementInteractions,
38
+ };
@@ -1,19 +1,19 @@
1
- const { assert } = require("./assertions");
2
- const { mouse } = require("./mouseActions");
3
- const { keyboard } = require("./keyboardActions");
4
- const { frame } = require("./frameActions");
5
- const { elementInteractions } = require("./elementInteractions");
6
- const { page } = require("./pageActions");
7
- const { api } = require("./APIActions");
8
- const { browser } = require("./browserActions");
9
-
10
- module.exports = {
11
- assert,
12
- mouse,
13
- keyboard,
14
- frame,
15
- elementInteractions,
16
- page,
17
- api,
18
- browser,
19
- };
1
+ const { assert } = require("./assertions");
2
+ const { mouse } = require("./mouseActions");
3
+ const { keyboard } = require("./keyboardActions");
4
+ const { frame } = require("./frameActions");
5
+ const { elementInteractions } = require("./elementInteractions");
6
+ const { page } = require("./pageActions");
7
+ const { api } = require("./APIActions");
8
+ const { browser } = require("./browserActions");
9
+
10
+ module.exports = {
11
+ assert,
12
+ mouse,
13
+ keyboard,
14
+ frame,
15
+ elementInteractions,
16
+ page,
17
+ api,
18
+ browser,
19
+ };
@@ -1,50 +1,50 @@
1
- const { element, moduleConfig } = require("../imports/commons");
2
- const path = require("path");
3
-
4
- const frame = {
5
- screenshot: async (selector) => {
6
- return await element(selector).screenshot({
7
- path: path.join(moduleConfig.projectPath, `${selector}.png`),
8
- });
9
- },
10
- contentFrame: async (selector) => {
11
- return await element(selector).contentFrame();
12
- },
13
- frameLocator: async (selector) => {
14
- return await element(selector).frameLocator();
15
- },
16
- nth: async (selector, index) => {
17
- return await element(selector).nth(index - 1);
18
- },
19
- first: async (selector) => {
20
- return await element(selector).first();
21
- },
22
- last: async (selector) => {
23
- return await element(selector).last();
24
- },
25
- filter: async (selector, filter) => {
26
- return await element(selector).filter(filter);
27
- },
28
- count: async (selector) => {
29
- return await element(selector).count();
30
- },
31
- getByAltText: async (text) => {
32
- return await element(text).getByAltText();
33
- },
34
- getByLabel: async (label) => {
35
- return await element(label).getByLabel();
36
- },
37
- getByPlaceholder: async (placeholder) => {
38
- return await element(placeholder).getByPlaceholder();
39
- },
40
- getByRole: async (role) => {
41
- return await element(role).getByRole();
42
- },
43
- getByTestId: async (testId) => {
44
- return await element(testId).getByTestId();
45
- },
46
- };
47
-
48
- module.exports = {
49
- frame,
50
- };
1
+ const { element, moduleConfig } = require("../imports/commons");
2
+ const path = require("path");
3
+
4
+ const frame = {
5
+ screenshot: async (selector) => {
6
+ return await element(selector).screenshot({
7
+ path: path.join(moduleConfig.projectPath, `${selector}.png`),
8
+ });
9
+ },
10
+ contentFrame: async (selector) => {
11
+ return await element(selector).contentFrame();
12
+ },
13
+ frameLocator: async (selector) => {
14
+ return await element(selector).frameLocator();
15
+ },
16
+ nth: async (selector, index) => {
17
+ return await element(selector).nth(index - 1);
18
+ },
19
+ first: async (selector) => {
20
+ return await element(selector).first();
21
+ },
22
+ last: async (selector) => {
23
+ return await element(selector).last();
24
+ },
25
+ filter: async (selector, filter) => {
26
+ return await element(selector).filter(filter);
27
+ },
28
+ count: async (selector) => {
29
+ return await element(selector).count();
30
+ },
31
+ getByAltText: async (text) => {
32
+ return await element(text).getByAltText();
33
+ },
34
+ getByLabel: async (label) => {
35
+ return await element(label).getByLabel();
36
+ },
37
+ getByPlaceholder: async (placeholder) => {
38
+ return await element(placeholder).getByPlaceholder();
39
+ },
40
+ getByRole: async (role) => {
41
+ return await element(role).getByRole();
42
+ },
43
+ getByTestId: async (testId) => {
44
+ return await element(testId).getByTestId();
45
+ },
46
+ };
47
+
48
+ module.exports = {
49
+ frame,
50
+ };
@@ -1,41 +1,41 @@
1
- const { element, resolveVariable } = require("../imports/commons");
2
-
3
- const keyboard = {
4
- press: async (selector, key) => {
5
- key = await resolveVariable(key);
6
- await element(selector).press(key);
7
- },
8
- pressSequentially: async (selector, keys) => {
9
- keys = await resolveVariable(keys);
10
- await element(selector).pressSequentially(keys);
11
- },
12
- pressSequentiallyDelay: async (selector, keys, delay) => {
13
- keys = await resolveVariable(keys);
14
- await element(selector).pressSequentially(keys, { delay: delay });
15
- },
16
- fill: async (selector, value) => {
17
- value = await resolveVariable(value);
18
- value !== "" ? await element(selector).fill(value) : "";
19
- },
20
- multipleElementFill: async (selectors, value) => {
21
- const elementCount = await frame.count(selectors);
22
- value = await resolveVariable(value);
23
- for (let i = 0; i < elementCount; i++) {
24
- await frame.nth(selectors, i).fill(value);
25
- }
26
- },
27
- clear: async (selector) => {
28
- await element(selector).clear();
29
- },
30
- selectText: async (selector) => {
31
- await element(selector).selectText();
32
- },
33
- setInputFiles: async (selector, files) => {
34
- files = await resolveVariable(files);
35
- await element(selector).setInputFiles(files);
36
- },
37
- };
38
-
39
- module.exports = {
40
- keyboard,
41
- };
1
+ const { element, resolveVariable } = require("../imports/commons");
2
+
3
+ const keyboard = {
4
+ press: async (selector, key) => {
5
+ key = await resolveVariable(key);
6
+ await element(selector).press(key);
7
+ },
8
+ pressSequentially: async (selector, keys) => {
9
+ keys = await resolveVariable(keys);
10
+ await element(selector).pressSequentially(keys);
11
+ },
12
+ pressSequentiallyDelay: async (selector, keys, delay) => {
13
+ keys = await resolveVariable(keys);
14
+ await element(selector).pressSequentially(keys, { delay: delay });
15
+ },
16
+ fill: async (selector, value) => {
17
+ value = await resolveVariable(value);
18
+ value !== "" ? await element(selector).fill(value) : "";
19
+ },
20
+ multipleElementFill: async (selectors, value) => {
21
+ const elementCount = await frame.count(selectors);
22
+ value = await resolveVariable(value);
23
+ for (let i = 0; i < elementCount; i++) {
24
+ await frame.nth(selectors, i).fill(value);
25
+ }
26
+ },
27
+ clear: async (selector) => {
28
+ await element(selector).clear();
29
+ },
30
+ selectText: async (selector) => {
31
+ await element(selector).selectText();
32
+ },
33
+ setInputFiles: async (selector, files) => {
34
+ files = await resolveVariable(files);
35
+ await element(selector).setInputFiles(files);
36
+ },
37
+ };
38
+
39
+ module.exports = {
40
+ keyboard,
41
+ };
@@ -1,145 +1,145 @@
1
- const path = require("path");
2
- const {
3
- element,
4
- context,
5
- selector,
6
- moduleConfig,
7
- } = require("../imports/commons");
8
- const { frame } = require("../stepFunctions/frameActions");
9
-
10
- const mouse = {
11
- click: async (selector) => {
12
- await element(selector).click();
13
- },
14
- multipleElementClick: async (selectors) => {
15
- const elementCount = await frame.count(selectors);
16
-
17
- for (let i = 0; i < elementCount; i++) {
18
- await frame.nth(selectors, i).click();
19
- }
20
- },
21
- forceClick: async (selector) => {
22
- await element(selector).click({ force: true });
23
- },
24
- clickPosition: async (selector, x, y) => {
25
- await element(selector).click({ position: { x: x, y: y } });
26
- },
27
- forceClickPosition: async (selector, x, y) => {
28
- await element(selector).click({ force: true, position: { x: x, y: y } });
29
- },
30
- rightClick: async (selector) => {
31
- await element(selector).click({ button: "right" });
32
- },
33
- multipleElementRightClick: async (elements) => {
34
- const elementCount = await frame.count(elements);
35
-
36
- for (let i = 0; i < elementCount; i++) {
37
- await frame.nth(elements, i).click({ button: "right" });
38
- }
39
- },
40
- forceRightClick: async (selector) => {
41
- await element(selector).click({ force: true, button: "right" });
42
- },
43
- leftClick: async (selector) => {
44
- await element(selector).click({ button: "left" });
45
- },
46
- multipleElementLeftClick: async (elements) => {
47
- const elementCount = await frame.count(elements);
48
-
49
- for (let i = 0; i < elementCount; i++) {
50
- await frame.nth(elements, i).click({ button: "left" });
51
- }
52
- },
53
- forceLeftClick: async (selector) => {
54
- await element(selector).click({ force: true, button: "left" });
55
- },
56
- doubleClick: async (selector) => {
57
- await element(selector).dblclick();
58
- },
59
- multipleElementDoubleClick: async (elements) => {
60
- const elementCount = await frame.count(elements);
61
-
62
- for (let i = 0; i < elementCount; i++) {
63
- await frame.nth(elements, i).dblclick();
64
- }
65
- },
66
- forceDoubleClick: async (selector) => {
67
- await element(selector).dblclick({ force: true });
68
- },
69
- forceDoubleClickPosition: async (selector, x, y) => {
70
- await element(selector).dblclick({ force: true, position: { x: x, y: y } });
71
- },
72
- hover: async (selector) => {
73
- await element(selector).hover();
74
- },
75
- forceHover: async (selector) => {
76
- await element(selector).hover({ force: true });
77
- },
78
- hoverPosition: async (selector, x, y) => {
79
- await element(selector).hover({ x: x, y: y });
80
- },
81
- forceHoverPosition: async (selector, x, y) => {
82
- await element(selector).hover({ force: true, x: x, y: y });
83
- },
84
- focus: async (selector) => {
85
- await element(selector).focus();
86
- },
87
- forceFocus: async (selector) => {
88
- await element(selector).focus({ force: true });
89
- },
90
- focusPosition: async (selector, x, y) => {
91
- await element(selector).focus({ x: x, y: y });
92
- },
93
- forceFocusPosition: async (selector, x, y) => {
94
- await element(selector).focus({ force: true, x: x, y: y });
95
- },
96
- dragAndDrop: async (sourceSelector, targetSelector) => {
97
- const source = await element(sourceSelector);
98
- const target = await element(targetSelector);
99
- await source.dragTo(target);
100
- },
101
- dragAndDropPosition: async (sourceSelector, x, y) => {
102
- await element(sourceSelector).dragTo({ targetPosition: { x: x, y: y } });
103
- },
104
- selectByValue: async (selector, value) => {
105
- const valueArray = value.split(",");
106
- value !== "" ? await element(selector).selectOption(valueArray) : "";
107
- },
108
- selectByText: async (selector, value) => {
109
- value !== "" ? await element(selector).selectOption(value) : "";
110
- },
111
- check: async (selector) => {
112
- await element(selector).check();
113
- },
114
- multipleElementCheck: async (selectors) => {
115
- const elementCount = await frame.count(selectors);
116
-
117
- for (let i = 0; i < elementCount; i++) {
118
- await frame.nth(selectors, i).check();
119
- }
120
- },
121
- uncheck: async (selector) => {
122
- await element(selector).uncheck();
123
- },
124
- multipleElementUncheck: async (selectors) => {
125
- const elementCount = await frame.count(selectors);
126
-
127
- for (let i = 0; i < elementCount; i++) {
128
- await frame.nth(selectors, i).uncheck();
129
- }
130
- },
131
- scrollIntoViewIfNeeded: async (selector) => {
132
- await element(selector).scrollIntoViewIfNeeded();
133
- },
134
- upload: async (filePath, fileInput) => {
135
- const file = selector(filePath);
136
- const fileChooserPromise = context.page.waitForEvent("filechooser");
137
- await element(fileInput).click();
138
- const fileChooser = await fileChooserPromise;
139
- await fileChooser.setFiles(path.join(moduleConfig.projectPath, file));
140
- },
141
- };
142
-
143
- module.exports = {
144
- mouse,
145
- };
1
+ const path = require("path");
2
+ const {
3
+ element,
4
+ context,
5
+ selector,
6
+ moduleConfig,
7
+ } = require("../imports/commons");
8
+ const { frame } = require("../stepFunctions/frameActions");
9
+
10
+ const mouse = {
11
+ click: async (selector) => {
12
+ await element(selector).click();
13
+ },
14
+ multipleElementClick: async (selectors) => {
15
+ const elementCount = await frame.count(selectors);
16
+
17
+ for (let i = 0; i < elementCount; i++) {
18
+ await frame.nth(selectors, i).click();
19
+ }
20
+ },
21
+ forceClick: async (selector) => {
22
+ await element(selector).click({ force: true });
23
+ },
24
+ clickPosition: async (selector, x, y) => {
25
+ await element(selector).click({ position: { x: x, y: y } });
26
+ },
27
+ forceClickPosition: async (selector, x, y) => {
28
+ await element(selector).click({ force: true, position: { x: x, y: y } });
29
+ },
30
+ rightClick: async (selector) => {
31
+ await element(selector).click({ button: "right" });
32
+ },
33
+ multipleElementRightClick: async (elements) => {
34
+ const elementCount = await frame.count(elements);
35
+
36
+ for (let i = 0; i < elementCount; i++) {
37
+ await frame.nth(elements, i).click({ button: "right" });
38
+ }
39
+ },
40
+ forceRightClick: async (selector) => {
41
+ await element(selector).click({ force: true, button: "right" });
42
+ },
43
+ leftClick: async (selector) => {
44
+ await element(selector).click({ button: "left" });
45
+ },
46
+ multipleElementLeftClick: async (elements) => {
47
+ const elementCount = await frame.count(elements);
48
+
49
+ for (let i = 0; i < elementCount; i++) {
50
+ await frame.nth(elements, i).click({ button: "left" });
51
+ }
52
+ },
53
+ forceLeftClick: async (selector) => {
54
+ await element(selector).click({ force: true, button: "left" });
55
+ },
56
+ doubleClick: async (selector) => {
57
+ await element(selector).dblclick();
58
+ },
59
+ multipleElementDoubleClick: async (elements) => {
60
+ const elementCount = await frame.count(elements);
61
+
62
+ for (let i = 0; i < elementCount; i++) {
63
+ await frame.nth(elements, i).dblclick();
64
+ }
65
+ },
66
+ forceDoubleClick: async (selector) => {
67
+ await element(selector).dblclick({ force: true });
68
+ },
69
+ forceDoubleClickPosition: async (selector, x, y) => {
70
+ await element(selector).dblclick({ force: true, position: { x: x, y: y } });
71
+ },
72
+ hover: async (selector) => {
73
+ await element(selector).hover();
74
+ },
75
+ forceHover: async (selector) => {
76
+ await element(selector).hover({ force: true });
77
+ },
78
+ hoverPosition: async (selector, x, y) => {
79
+ await element(selector).hover({ x: x, y: y });
80
+ },
81
+ forceHoverPosition: async (selector, x, y) => {
82
+ await element(selector).hover({ force: true, x: x, y: y });
83
+ },
84
+ focus: async (selector) => {
85
+ await element(selector).focus();
86
+ },
87
+ forceFocus: async (selector) => {
88
+ await element(selector).focus({ force: true });
89
+ },
90
+ focusPosition: async (selector, x, y) => {
91
+ await element(selector).focus({ x: x, y: y });
92
+ },
93
+ forceFocusPosition: async (selector, x, y) => {
94
+ await element(selector).focus({ force: true, x: x, y: y });
95
+ },
96
+ dragAndDrop: async (sourceSelector, targetSelector) => {
97
+ const source = await element(sourceSelector);
98
+ const target = await element(targetSelector);
99
+ await source.dragTo(target);
100
+ },
101
+ dragAndDropPosition: async (sourceSelector, x, y) => {
102
+ await element(sourceSelector).dragTo({ targetPosition: { x: x, y: y } });
103
+ },
104
+ selectByValue: async (selector, value) => {
105
+ const valueArray = value.split(",");
106
+ value !== "" ? await element(selector).selectOption(valueArray) : "";
107
+ },
108
+ selectByText: async (selector, value) => {
109
+ value !== "" ? await element(selector).selectOption(value) : "";
110
+ },
111
+ check: async (selector) => {
112
+ await element(selector).check();
113
+ },
114
+ multipleElementCheck: async (selectors) => {
115
+ const elementCount = await frame.count(selectors);
116
+
117
+ for (let i = 0; i < elementCount; i++) {
118
+ await frame.nth(selectors, i).check();
119
+ }
120
+ },
121
+ uncheck: async (selector) => {
122
+ await element(selector).uncheck();
123
+ },
124
+ multipleElementUncheck: async (selectors) => {
125
+ const elementCount = await frame.count(selectors);
126
+
127
+ for (let i = 0; i < elementCount; i++) {
128
+ await frame.nth(selectors, i).uncheck();
129
+ }
130
+ },
131
+ scrollIntoViewIfNeeded: async (selector) => {
132
+ await element(selector).scrollIntoViewIfNeeded();
133
+ },
134
+ upload: async (filePath, fileInput) => {
135
+ const file = selector(filePath);
136
+ const fileChooserPromise = context.page.waitForEvent("filechooser");
137
+ await element(fileInput).click();
138
+ const fileChooser = await fileChooserPromise;
139
+ await fileChooser.setFiles(path.join(moduleConfig.projectPath, file));
140
+ },
141
+ };
142
+
143
+ module.exports = {
144
+ mouse,
145
+ };