@zohodesk/testinglibrary 3.2.20 → 3.3.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.
- package/.gitlab-ci.yml +11 -14
- package/README.md +5 -1
- package/build/core/playwright/clear-caches.js +5 -2
- package/build/core/playwright/constants/configConstants.js +3 -6
- package/build/core/playwright/constants/reporterConstants.js +6 -2
- package/build/core/playwright/constants/retryConstants.js +8 -0
- package/build/core/playwright/helpers/auth/index.js +8 -1
- package/build/core/playwright/readConfigFile.js +5 -3
- package/build/core/playwright/runner/SpawnRunner.js +20 -1
- package/build/core/playwright/setup/ProjectConfiguration.js +9 -26
- package/build/core/playwright/setup/config-creator.js +8 -5
- package/build/core/playwright/setup/config-utils.js +7 -3
- package/build/core/playwright/setup/qc-custom-reporter.js +4 -1
- package/build/core/playwright/test-runner.js +0 -4
- package/build/index.js +6 -0
- package/build/utils/commonUtils.js +4 -1
- package/npm-shrinkwrap.json +346 -303
- package/package.json +1 -1
- package/playwright.config.js +10 -7
- package/build/test/Test.js +0 -13
package/.gitlab-ci.yml
CHANGED
|
@@ -55,7 +55,7 @@ uat-auth:
|
|
|
55
55
|
artifacts:
|
|
56
56
|
when: always
|
|
57
57
|
paths:
|
|
58
|
-
- examples/uat/playwright-report
|
|
58
|
+
- examples/test-slices/uat/playwright-report
|
|
59
59
|
|
|
60
60
|
uat-noauth:
|
|
61
61
|
stage: uat
|
|
@@ -69,7 +69,7 @@ uat-noauth:
|
|
|
69
69
|
artifacts:
|
|
70
70
|
when: always
|
|
71
71
|
paths:
|
|
72
|
-
- examples/uat/playwright-report
|
|
72
|
+
- examples/test-slices/uat/playwright-report
|
|
73
73
|
|
|
74
74
|
uat-profile:
|
|
75
75
|
stage: uat
|
|
@@ -83,7 +83,7 @@ uat-profile:
|
|
|
83
83
|
artifacts:
|
|
84
84
|
when: always
|
|
85
85
|
paths:
|
|
86
|
-
- examples/uat/playwright-report
|
|
86
|
+
- examples/test-slices/uat/playwright-report
|
|
87
87
|
|
|
88
88
|
|
|
89
89
|
uat-unauth:
|
|
@@ -99,7 +99,7 @@ uat-unauth:
|
|
|
99
99
|
artifacts:
|
|
100
100
|
when: always
|
|
101
101
|
paths:
|
|
102
|
-
- examples/uat/playwright-report
|
|
102
|
+
- examples/test-slices/uat/playwright-report
|
|
103
103
|
|
|
104
104
|
uat-nobdd:
|
|
105
105
|
stage: uat
|
|
@@ -114,7 +114,7 @@ uat-nobdd:
|
|
|
114
114
|
artifacts:
|
|
115
115
|
when: always
|
|
116
116
|
paths:
|
|
117
|
-
- nobdd/uat/playwright-report
|
|
117
|
+
- nobdd/test-slices/uat/playwright-report
|
|
118
118
|
|
|
119
119
|
|
|
120
120
|
uatmodule:
|
|
@@ -130,7 +130,7 @@ uatmodule:
|
|
|
130
130
|
artifacts:
|
|
131
131
|
when: always
|
|
132
132
|
paths:
|
|
133
|
-
- examples/uat/playwright-report
|
|
133
|
+
- examples/test-slices/uat/playwright-report
|
|
134
134
|
|
|
135
135
|
uatconfigmodule:
|
|
136
136
|
stage: uat
|
|
@@ -144,7 +144,7 @@ uatconfigmodule:
|
|
|
144
144
|
artifacts:
|
|
145
145
|
when: always
|
|
146
146
|
paths:
|
|
147
|
-
- examples/uat/playwright-report
|
|
147
|
+
- examples/test-slices/uat/playwright-report
|
|
148
148
|
|
|
149
149
|
uat-smoketest:
|
|
150
150
|
stage: uat
|
|
@@ -158,7 +158,7 @@ uat-smoketest:
|
|
|
158
158
|
artifacts:
|
|
159
159
|
when: always
|
|
160
160
|
paths:
|
|
161
|
-
- examples/uat/playwright-report
|
|
161
|
+
- examples/test-slices/uat/playwright-report
|
|
162
162
|
|
|
163
163
|
uat-multiactor:
|
|
164
164
|
stage: uat
|
|
@@ -172,7 +172,7 @@ uat-multiactor:
|
|
|
172
172
|
artifacts:
|
|
173
173
|
when: always
|
|
174
174
|
paths:
|
|
175
|
-
- examples/uat/playwright-report
|
|
175
|
+
- examples/test-slices/uat/playwright-report
|
|
176
176
|
|
|
177
177
|
uat-data_generator:
|
|
178
178
|
stage: uat
|
|
@@ -186,7 +186,7 @@ uat-data_generator:
|
|
|
186
186
|
artifacts:
|
|
187
187
|
when: always
|
|
188
188
|
paths:
|
|
189
|
-
- examples/uat/playwright-report
|
|
189
|
+
- examples/test-slices/uat/playwright-report
|
|
190
190
|
|
|
191
191
|
uat-search_indexing:
|
|
192
192
|
stage: uat
|
|
@@ -202,7 +202,4 @@ uat-search_indexing:
|
|
|
202
202
|
artifacts:
|
|
203
203
|
when: always
|
|
204
204
|
paths:
|
|
205
|
-
- examples/uat/playwright-report
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
205
|
+
- examples/test-slices/uat/playwright-report
|
package/README.md
CHANGED
|
@@ -17,12 +17,16 @@
|
|
|
17
17
|
|
|
18
18
|
- npm run report
|
|
19
19
|
|
|
20
|
+
### v4.0.6/v3.2.21 - 22-01-2026
|
|
21
|
+
|
|
22
|
+
#### Bug fix
|
|
23
|
+
- Retry added for Missing Step Definitions Issue in the Feature Files
|
|
24
|
+
|
|
20
25
|
### v4.0.4/v3.2.20 - 19-12-2025
|
|
21
26
|
|
|
22
27
|
#### Enhancement
|
|
23
28
|
- New common step provided for search index with the data generated entity
|
|
24
29
|
|
|
25
|
-
|
|
26
30
|
### v4.0.3/v3.2.19 - 17-12-2025
|
|
27
31
|
|
|
28
32
|
#### Enhancement
|
|
@@ -10,6 +10,9 @@ var _fileUtils = require("../../utils/fileUtils");
|
|
|
10
10
|
var _logger = require("../../utils/logger");
|
|
11
11
|
var _readConfigFile = require("./readConfigFile");
|
|
12
12
|
var _checkAuthDirectory = require("./helpers/checkAuthDirectory");
|
|
13
|
+
var _configConstants = _interopRequireDefault(require("./constants/configConstants"));
|
|
14
|
+
var _ConfigurationHelper = require("./configuration/ConfigurationHelper");
|
|
15
|
+
const stage = (0, _ConfigurationHelper.getRunStage)();
|
|
13
16
|
function deleteAuthFiles(authFilePath) {
|
|
14
17
|
authFilePath = _path.default.resolve(process.cwd(), authFilePath);
|
|
15
18
|
const authFileFolder = _path.default.dirname(authFilePath);
|
|
@@ -21,7 +24,7 @@ function deletePlaywrightReport(reportPath) {
|
|
|
21
24
|
(0, _fileUtils.deleteFolder)(reportPath);
|
|
22
25
|
}
|
|
23
26
|
function deleteGeneratedFeatures() {
|
|
24
|
-
const featuresGenPath = _path.default.resolve(process.cwd(),
|
|
27
|
+
const featuresGenPath = _path.default.resolve(process.cwd(), _configConstants.default.TEST_SLICE_FOLDER, stage, '.features-gen');
|
|
25
28
|
_logger.Logger.log(_logger.Logger.INFO_TYPE, `Deleting generated features at ${featuresGenPath}`);
|
|
26
29
|
(0, _fileUtils.deleteFolder)(featuresGenPath);
|
|
27
30
|
}
|
|
@@ -43,7 +46,7 @@ function clearCaches() {
|
|
|
43
46
|
_logger.Logger.log(_logger.Logger.SUCCESS_TYPE, 'Caches Cleared. Now you can try running npm run uat');
|
|
44
47
|
} catch (err) {
|
|
45
48
|
_logger.Logger.error(err);
|
|
46
|
-
_logger.Logger.log(_logger.Logger.FAILURE_TYPE,
|
|
49
|
+
_logger.Logger.log(_logger.Logger.FAILURE_TYPE, `Error While clearing cookies. Try manually delete folder ${_configConstants.default.TEST_SLICE_FOLDER}/playwright and ${_configConstants.default.TEST_SLICE_FOLDER}/playwright-report`);
|
|
47
50
|
}
|
|
48
51
|
}
|
|
49
52
|
var _default = exports.default = clearCaches;
|
|
@@ -1,9 +1,5 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
3
|
class configConstants {
|
|
8
4
|
static DEFAULT_CONFIG_DIR = 'default';
|
|
9
5
|
static BETA_DIR = 'beta';
|
|
@@ -12,6 +8,7 @@ class configConstants {
|
|
|
12
8
|
static INDEX_FILE = 'index.js';
|
|
13
9
|
static SETTINGS_FILE = 'settings.json';
|
|
14
10
|
static TEST_SUMMARY_FILE = 'test-summary.json';
|
|
15
|
-
static STAGE_CONFIG_MAP_FILE = '
|
|
11
|
+
static STAGE_CONFIG_MAP_FILE = 'test-slices/conf_path_map.properties';
|
|
12
|
+
static TEST_SLICE_FOLDER = 'test-slices';
|
|
16
13
|
}
|
|
17
|
-
exports
|
|
14
|
+
module.exports = configConstants;
|
|
@@ -1,11 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
3
4
|
Object.defineProperty(exports, "__esModule", {
|
|
4
5
|
value: true
|
|
5
6
|
});
|
|
6
7
|
exports.default = void 0;
|
|
8
|
+
var _configConstants = _interopRequireDefault(require("./configConstants"));
|
|
9
|
+
var _ConfigurationHelper = require("../configuration/ConfigurationHelper");
|
|
10
|
+
const stage = (0, _ConfigurationHelper.getRunStage)();
|
|
7
11
|
class ReporterConstants {
|
|
8
|
-
static DEFAULT_REPORTER_PATH =
|
|
9
|
-
static LAST_RUN_REPORTER_PATH =
|
|
12
|
+
static DEFAULT_REPORTER_PATH = `${_configConstants.default.TEST_SLICE_FOLDER}/${stage}/test-results/playwright-test-results.json`;
|
|
13
|
+
static LAST_RUN_REPORTER_PATH = `${_configConstants.default.TEST_SLICE_FOLDER}/${stage}/test-results/.last-run.json`;
|
|
10
14
|
}
|
|
11
15
|
exports.default = ReporterConstants;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.PREPROCESSING_RETRY_MAX_ATTEMPTS = exports.PREPROCESSING_RETRY_DELAY_MS = void 0;
|
|
7
|
+
const PREPROCESSING_RETRY_MAX_ATTEMPTS = exports.PREPROCESSING_RETRY_MAX_ATTEMPTS = 1;
|
|
8
|
+
const PREPROCESSING_RETRY_DELAY_MS = exports.PREPROCESSING_RETRY_DELAY_MS = 2000;
|
|
@@ -34,6 +34,12 @@ Object.defineProperty(exports, "getRunMode", {
|
|
|
34
34
|
return _getUsers.getRunMode;
|
|
35
35
|
}
|
|
36
36
|
});
|
|
37
|
+
Object.defineProperty(exports, "getRunStage", {
|
|
38
|
+
enumerable: true,
|
|
39
|
+
get: function () {
|
|
40
|
+
return _ConfigurationHelper.getRunStage;
|
|
41
|
+
}
|
|
42
|
+
});
|
|
37
43
|
Object.defineProperty(exports, "getUserForSelectedEditionAndProfile", {
|
|
38
44
|
enumerable: true,
|
|
39
45
|
get: function () {
|
|
@@ -73,4 +79,5 @@ Object.defineProperty(exports, "verifyIfCookieFileExists", {
|
|
|
73
79
|
var _accountLogin = _interopRequireDefault(require("./accountLogin"));
|
|
74
80
|
var _checkAuthCookies = require("./checkAuthCookies");
|
|
75
81
|
var _getUsers = require("./getUsers");
|
|
76
|
-
var _loginSteps = _interopRequireDefault(require("./loginSteps"));
|
|
82
|
+
var _loginSteps = _interopRequireDefault(require("./loginSteps"));
|
|
83
|
+
var _ConfigurationHelper = require("../../configuration/ConfigurationHelper");
|
|
@@ -17,6 +17,8 @@ var _Configuration = _interopRequireDefault(require("./configuration/Configurati
|
|
|
17
17
|
var _UserArgs = _interopRequireDefault(require("./configuration/UserArgs"));
|
|
18
18
|
var _ConfigurationHelper = require("./configuration/ConfigurationHelper");
|
|
19
19
|
var _auth = require("./helpers/auth");
|
|
20
|
+
var _configConstants = _interopRequireDefault(require("./constants/configConstants"));
|
|
21
|
+
const stage = (0, _ConfigurationHelper.getRunStage)();
|
|
20
22
|
let cachedConfig = null;
|
|
21
23
|
function getPrimaryCookiePath() {
|
|
22
24
|
const {
|
|
@@ -24,12 +26,12 @@ function getPrimaryCookiePath() {
|
|
|
24
26
|
} = (0, _auth.getDefaultActor)();
|
|
25
27
|
const authFilePrefix = process.env.authFilePrefix;
|
|
26
28
|
let authFileName = authFilePrefix ? `${authFilePrefix}-${email}` : `${email}`;
|
|
27
|
-
return
|
|
29
|
+
return `${_configConstants.default.TEST_SLICE_FOLDER}/${stage}/playwright/.auth/${authFileName}-cookies.json`;
|
|
28
30
|
}
|
|
29
31
|
function getDefaultConfig() {
|
|
30
32
|
return {
|
|
31
33
|
isTearDown: true,
|
|
32
|
-
uatDirectory: _path.default.join(process.cwd(),
|
|
34
|
+
uatDirectory: _path.default.join(process.cwd(), _configConstants.default.TEST_SLICE_FOLDER, stage),
|
|
33
35
|
headless: false,
|
|
34
36
|
browsers: ['Chrome'],
|
|
35
37
|
forbidOnly: false,
|
|
@@ -38,7 +40,7 @@ function getDefaultConfig() {
|
|
|
38
40
|
video: false,
|
|
39
41
|
isAuthMode: false,
|
|
40
42
|
openReportOn: 'never',
|
|
41
|
-
reportPath: _path.default.join(process.cwd(),
|
|
43
|
+
reportPath: _path.default.join(process.cwd(), _configConstants.default.TEST_SLICE_FOLDER, stage, 'playwright-report'),
|
|
42
44
|
bddMode: false,
|
|
43
45
|
expectTimeout: 5 * 1000,
|
|
44
46
|
testTimeout: 60 * 1000,
|
|
@@ -9,6 +9,7 @@ var _child_process = require("child_process");
|
|
|
9
9
|
var _RunnerHelper = _interopRequireDefault(require("./RunnerHelper"));
|
|
10
10
|
var _Runner = _interopRequireDefault(require("./Runner"));
|
|
11
11
|
var _commonUtils = require("../../../utils/commonUtils");
|
|
12
|
+
var _retryConstants = require("../../playwright/constants/retryConstants");
|
|
12
13
|
class SpawnRunner extends _Runner.default {
|
|
13
14
|
constructor(runnerObj) {
|
|
14
15
|
super(runnerObj);
|
|
@@ -23,13 +24,31 @@ class SpawnRunner extends _Runner.default {
|
|
|
23
24
|
bddMode
|
|
24
25
|
} = config.getAll();
|
|
25
26
|
if (bddMode) {
|
|
26
|
-
promises.push(this.
|
|
27
|
+
promises.push(this.runPreprocessingWithRetry());
|
|
27
28
|
}
|
|
28
29
|
Promise.all(promises).then(() => this.runPlaywright()).catch(err => {
|
|
29
30
|
_logger.Logger.error(err);
|
|
30
31
|
process.exit();
|
|
31
32
|
});
|
|
32
33
|
}
|
|
34
|
+
|
|
35
|
+
// This below Retry wrapper function for preprocessing the feature files Missing Step Definitions Issue
|
|
36
|
+
|
|
37
|
+
async runPreprocessingWithRetry(maxRetries = _retryConstants.PREPROCESSING_RETRY_MAX_ATTEMPTS, delayMs = _retryConstants.PREPROCESSING_RETRY_DELAY_MS) {
|
|
38
|
+
for (let attempt = 1; attempt <= maxRetries + 1; attempt++) {
|
|
39
|
+
try {
|
|
40
|
+
await this.runPreprocessing();
|
|
41
|
+
return;
|
|
42
|
+
} catch (err) {
|
|
43
|
+
if (attempt > maxRetries) {
|
|
44
|
+
_logger.Logger.log(_logger.Logger.FAILURE_TYPE, `Preprocessing failed after ${attempt} attempts`);
|
|
45
|
+
throw err;
|
|
46
|
+
}
|
|
47
|
+
_logger.Logger.log(_logger.Logger.INFO_TYPE, `Preprocessing failed (attempt ${attempt} of ${maxRetries + 1}). Retrying in ${delayMs}ms...`);
|
|
48
|
+
await new Promise(resolve => setTimeout(resolve, delayMs));
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
33
52
|
runPreprocessing() {
|
|
34
53
|
//This below functoin is called to copy the data generator spec files to the current project
|
|
35
54
|
(0, _commonUtils.copyCommonSpecs)();
|
|
@@ -11,6 +11,9 @@ var _path = _interopRequireDefault(require("path"));
|
|
|
11
11
|
var _Project = require("./Project");
|
|
12
12
|
var _configUtils = require("./config-utils");
|
|
13
13
|
var _readConfigFile = require("../readConfigFile");
|
|
14
|
+
var _configConstants = _interopRequireDefault(require("../constants/configConstants"));
|
|
15
|
+
var _ConfigurationHelper = require("../configuration/ConfigurationHelper");
|
|
16
|
+
const stage = (0, _ConfigurationHelper.getRunStage)();
|
|
14
17
|
const uatConfig = (0, _readConfigFile.generateConfigFromFile)();
|
|
15
18
|
const {
|
|
16
19
|
isAuthMode,
|
|
@@ -25,7 +28,7 @@ const {
|
|
|
25
28
|
function setupConfig() {
|
|
26
29
|
const setupProject = new _Project.Project('setup');
|
|
27
30
|
setupProject.setTestMatch(/.*\.setup\.js/);
|
|
28
|
-
setupProject.setTestDir(_path.default.join(process.cwd(),
|
|
31
|
+
setupProject.setTestDir(_path.default.join(process.cwd(), _configConstants.default.TEST_SLICE_FOLDER));
|
|
29
32
|
const isTearDown = JSON.parse(process.env.tearDown);
|
|
30
33
|
setupProject.setTearDown(isTearDown ? 'cleanup' : '');
|
|
31
34
|
const setupProjectConfig = [setupProject.getProperties()];
|
|
@@ -34,10 +37,10 @@ function setupConfig() {
|
|
|
34
37
|
function smokeTestConfig() {
|
|
35
38
|
const smokeTestProject = new _Project.Project('smokeTest');
|
|
36
39
|
const smokeTestDir = (0, _configUtils.getTestDir)(bddMode, {
|
|
37
|
-
featureFilesFolder: _path.default.join(process.cwd(),
|
|
38
|
-
stepDefinitionsFolder: _path.default.join(process.cwd(), '
|
|
39
|
-
outputDir: _path.default.join(process.cwd(),
|
|
40
|
-
uatPath: _path.default.join(process.cwd(),
|
|
40
|
+
featureFilesFolder: _path.default.join(process.cwd(), _configConstants.default.TEST_SLICE_FOLDER, stage, 'smokeTest', '**', '*.feature'),
|
|
41
|
+
stepDefinitionsFolder: _path.default.join(process.cwd(), _configConstants.default.TEST_SLICE_FOLDER, '**', '**', 'steps', '*.spec.js'),
|
|
42
|
+
outputDir: _path.default.join(process.cwd(), _configConstants.default.TEST_SLICE_FOLDER, stage, '.features-smoke-gen'),
|
|
43
|
+
uatPath: _path.default.join(process.cwd(), _configConstants.default.TEST_SLICE_FOLDER, stage, 'smokeTest')
|
|
41
44
|
});
|
|
42
45
|
const commonConfig = {
|
|
43
46
|
storageState: isAuthMode ? (0, _readConfigFile.getAuthFilePath)(_path.default.resolve(process.cwd(), authFilePath)) : {}
|
|
@@ -51,30 +54,10 @@ function smokeTestConfig() {
|
|
|
51
54
|
const smokeTestProjectConfig = [smokeTestProject.getProperties()];
|
|
52
55
|
return smokeTestProjectConfig;
|
|
53
56
|
}
|
|
54
|
-
function defaultConfig() {
|
|
55
|
-
const defaultProject = new _Project.Project('default');
|
|
56
|
-
const testDir = (0, _configUtils.getTestDir)(bddMode, {
|
|
57
|
-
featureFilesFolder: (0, _configUtils.getPathsForFeatureFiles)(process.cwd()),
|
|
58
|
-
stepDefinitionsFolder: _path.default.join(process.cwd(), 'uat', '**', 'steps', '*.spec.js'),
|
|
59
|
-
outputDir: _path.default.join(process.cwd(), 'uat', '.features-gen'),
|
|
60
|
-
uatPath: _path.default.join(process.cwd(), 'uat')
|
|
61
|
-
});
|
|
62
|
-
const use = {
|
|
63
|
-
trace,
|
|
64
|
-
video,
|
|
65
|
-
viewport,
|
|
66
|
-
testIdAttribute
|
|
67
|
-
};
|
|
68
|
-
defaultProject.setUse(use);
|
|
69
|
-
defaultProject.setTestDir(testDir);
|
|
70
|
-
defaultProject.setDependencies(isSmokeTest ? ['smokeTest'] : []);
|
|
71
|
-
const defaultProjectConfig = [defaultProject.getProperties()];
|
|
72
|
-
return defaultProjectConfig;
|
|
73
|
-
}
|
|
74
57
|
function cleanupConfig() {
|
|
75
58
|
const cleanupProject = new _Project.Project('cleanup');
|
|
76
59
|
cleanupProject.setTestMatch(/.*\.teardown\.js/);
|
|
77
|
-
cleanupProject.setTestDir(_path.default.join(process.cwd(),
|
|
60
|
+
cleanupProject.setTestDir(_path.default.join(process.cwd(), _configConstants.default.TEST_SLICE_FOLDER));
|
|
78
61
|
const cleanupProjectConfig = [cleanupProject.getProperties()];
|
|
79
62
|
return cleanupProjectConfig;
|
|
80
63
|
}
|
|
@@ -10,7 +10,10 @@ var _path = _interopRequireDefault(require("path"));
|
|
|
10
10
|
var _readConfigFile = require("../readConfigFile");
|
|
11
11
|
var _configUtils = require("./config-utils");
|
|
12
12
|
var _ProjectConfiguration = require("./ProjectConfiguration");
|
|
13
|
+
var _ConfigurationHelper = require("../configuration/ConfigurationHelper");
|
|
14
|
+
var _configConstants = _interopRequireDefault(require("../constants/configConstants"));
|
|
13
15
|
const uatConfig = (0, _readConfigFile.generateConfigFromFile)();
|
|
16
|
+
const stage = (0, _ConfigurationHelper.getRunStage)();
|
|
14
17
|
const {
|
|
15
18
|
bddMode,
|
|
16
19
|
browsers,
|
|
@@ -41,7 +44,7 @@ let reporter = [['html', {
|
|
|
41
44
|
outputFolder: reportPath,
|
|
42
45
|
open: openReportOn
|
|
43
46
|
}], ['list'], ['json', {
|
|
44
|
-
outputFile: _path.default.join(process.cwd(),
|
|
47
|
+
outputFile: _path.default.join(process.cwd(), _configConstants.default.TEST_SLICE_FOLDER, stage, 'test-results', 'playwright-test-results.json')
|
|
45
48
|
}], ['./custom-reporter.js'], ['./qc-custom-reporter.js']];
|
|
46
49
|
if (customReporter) {
|
|
47
50
|
reporter = [customReporter, ...reporter];
|
|
@@ -61,9 +64,9 @@ const use = {
|
|
|
61
64
|
};
|
|
62
65
|
const testDir = (0, _configUtils.getTestDir)(bddMode, {
|
|
63
66
|
featureFilesFolder: (0, _configUtils.getPathsForFeatureFiles)(process.cwd()),
|
|
64
|
-
stepDefinitionsFolder: _path.default.join(process.cwd(), '
|
|
65
|
-
outputDir: _path.default.join(process.cwd(),
|
|
66
|
-
uatPath: _path.default.join(process.cwd(),
|
|
67
|
+
stepDefinitionsFolder: _path.default.join(process.cwd(), _configConstants.default.TEST_SLICE_FOLDER, '**', '**', 'steps', '*.spec.js'),
|
|
68
|
+
outputDir: _path.default.join(process.cwd(), _configConstants.default.TEST_SLICE_FOLDER, stage, '.features-gen'),
|
|
69
|
+
uatPath: _path.default.join(process.cwd(), _configConstants.default.TEST_SLICE_FOLDER, stage)
|
|
67
70
|
});
|
|
68
71
|
function getPlaywrightConfig() {
|
|
69
72
|
const smokeTestProject = isSmokeTest ? (0, _ProjectConfiguration.smokeTestConfig)() : [];
|
|
@@ -73,7 +76,7 @@ function getPlaywrightConfig() {
|
|
|
73
76
|
const playwrightConfig = {
|
|
74
77
|
testDir,
|
|
75
78
|
globalTimeout: globalTimeout || 3600000,
|
|
76
|
-
outputDir: _path.default.join(process.cwd(),
|
|
79
|
+
outputDir: _path.default.join(process.cwd(), _configConstants.default.TEST_SLICE_FOLDER, stage, 'test-results'),
|
|
77
80
|
fullyParallel: true,
|
|
78
81
|
reporter,
|
|
79
82
|
timeout: testTimeout,
|
|
@@ -16,11 +16,14 @@ var _playwrightBdd = require("playwright-bdd");
|
|
|
16
16
|
var _logger = require("../../../utils/logger");
|
|
17
17
|
var _browserTypes = require("../constants/browserTypes");
|
|
18
18
|
var _fileUtils = require("../../../utils/fileUtils");
|
|
19
|
+
var _ConfigurationHelper = require("../configuration/ConfigurationHelper");
|
|
20
|
+
var _configConstants = _interopRequireDefault(require("../constants/configConstants"));
|
|
19
21
|
/**
|
|
20
22
|
** Playwright project configuration
|
|
21
23
|
* @returns {import('@playwright/test').Project}
|
|
22
24
|
*/
|
|
23
25
|
|
|
26
|
+
const stage = (0, _ConfigurationHelper.getRunStage)();
|
|
24
27
|
function getBrowserConfig({
|
|
25
28
|
browserName,
|
|
26
29
|
isAuthMode,
|
|
@@ -142,7 +145,8 @@ function getPathsForFeatureFiles(cwd) {
|
|
|
142
145
|
const {
|
|
143
146
|
failed = []
|
|
144
147
|
} = JSON.parse(testSummary);
|
|
145
|
-
const casesToRun = failed.map(filePath => _path.default.join(cwd,
|
|
148
|
+
const casesToRun = failed.map(filePath => _path.default.join(cwd, _configConstants.default.TEST_SLICE_FOLDER, filePath.replace(/\.spec\.js$|\.js$/, '')));
|
|
149
|
+
;
|
|
146
150
|
return casesToRun;
|
|
147
151
|
} else {
|
|
148
152
|
_logger.Logger.log(_logger.Logger.INFO_TYPE, `Unable to read test summary from the ${reportPath}. Verify If File Exists in the path`);
|
|
@@ -153,12 +157,12 @@ function getPathsForFeatureFiles(cwd) {
|
|
|
153
157
|
let moduleList = modules.split(',');
|
|
154
158
|
return getModulePathForFeatureFiles(moduleList);
|
|
155
159
|
}
|
|
156
|
-
return [_path.default.join(cwd,
|
|
160
|
+
return [_path.default.join(cwd, _configConstants.default.TEST_SLICE_FOLDER, stage, 'modules', '**', 'feature-files', '*.feature')];
|
|
157
161
|
}
|
|
158
162
|
function getModulePathForFeatureFiles(moduleList) {
|
|
159
163
|
let validModuleList = [];
|
|
160
164
|
moduleList.forEach(moduleName => {
|
|
161
|
-
let modulePath = _path.default.join(process.cwd(), '
|
|
165
|
+
let modulePath = _path.default.join(process.cwd(), _configConstants.default.TEST_SLICE_FOLDER, '**', 'modules', '**', `${moduleName}`);
|
|
162
166
|
if ((0, _fileUtils.checkIfFolderExistsWithPattern)(modulePath)) {
|
|
163
167
|
validModuleList.push(_path.default.join(modulePath, '**', '*.feature'));
|
|
164
168
|
} else {
|
|
@@ -8,11 +8,14 @@ exports.default = void 0;
|
|
|
8
8
|
var _fs = _interopRequireDefault(require("fs"));
|
|
9
9
|
var _path = _interopRequireDefault(require("path"));
|
|
10
10
|
var _codeFrame = require("@babel/code-frame");
|
|
11
|
+
var _configConstants = _interopRequireDefault(require("../constants/configConstants"));
|
|
12
|
+
var _ConfigurationHelper = require("../configuration/ConfigurationHelper");
|
|
13
|
+
const stage = (0, _ConfigurationHelper.getRunStage)();
|
|
11
14
|
class CustomJsonReporter {
|
|
12
15
|
constructor({
|
|
13
16
|
outputFile = 'test-results.json'
|
|
14
17
|
} = {}) {
|
|
15
|
-
this.outputFile = _path.default.resolve(process.cwd(), '
|
|
18
|
+
this.outputFile = _path.default.resolve(process.cwd(), _configConstants.default.TEST_SLICE_FOLDER, stage, 'test-results/', outputFile);
|
|
16
19
|
this.rootSuite = null;
|
|
17
20
|
this.report = {
|
|
18
21
|
config: {},
|
|
@@ -8,15 +8,11 @@ exports.default = void 0;
|
|
|
8
8
|
exports.runPreprocessing = runPreprocessing;
|
|
9
9
|
var _child_process = require("child_process");
|
|
10
10
|
var _path = _interopRequireDefault(require("path"));
|
|
11
|
-
var _customCommands = require("./custom-commands");
|
|
12
|
-
var _cliArgsToObject = require("../../utils/cliArgsToObject");
|
|
13
11
|
var _envInitializer = require("./env-initializer");
|
|
14
12
|
var _logger = require("../../utils/logger");
|
|
15
13
|
var _readConfigFile = require("./readConfigFile");
|
|
16
14
|
var _rootPath = require("../../utils/rootPath");
|
|
17
15
|
var _tagProcessor = _interopRequireDefault(require("./tagProcessor"));
|
|
18
|
-
var _configUtils = require("./setup/config-utils");
|
|
19
|
-
var _browserTypes = require("./constants/browserTypes");
|
|
20
16
|
var _ConfigurationHelper = require("./configuration/ConfigurationHelper");
|
|
21
17
|
var _Configuration = _interopRequireDefault(require("./configuration/Configuration"));
|
|
22
18
|
var _UserArgs = _interopRequireDefault(require("./configuration/UserArgs"));
|
package/build/index.js
CHANGED
|
@@ -40,6 +40,12 @@ Object.defineProperty(exports, "getRunMode", {
|
|
|
40
40
|
return _index.getRunMode;
|
|
41
41
|
}
|
|
42
42
|
});
|
|
43
|
+
Object.defineProperty(exports, "getRunStage", {
|
|
44
|
+
enumerable: true,
|
|
45
|
+
get: function () {
|
|
46
|
+
return _index.getRunStage;
|
|
47
|
+
}
|
|
48
|
+
});
|
|
43
49
|
Object.defineProperty(exports, "getUserForSelectedEditionAndProfile", {
|
|
44
50
|
enumerable: true,
|
|
45
51
|
get: function () {
|
|
@@ -7,11 +7,14 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
7
7
|
exports.copyCommonSpecs = copyCommonSpecs;
|
|
8
8
|
var _fileUtils = require("./fileUtils");
|
|
9
9
|
var _path = _interopRequireDefault(require("path"));
|
|
10
|
+
var _configConstants = _interopRequireDefault(require("../core/playwright/constants/configConstants"));
|
|
11
|
+
var _ConfigurationHelper = require("../core/playwright/configuration/ConfigurationHelper");
|
|
12
|
+
const stage = (0, _ConfigurationHelper.getRunStage)();
|
|
10
13
|
function copyCommonSpecs() {
|
|
11
14
|
const libraryPath = require.resolve("@zohodesk/testinglibrary");
|
|
12
15
|
// libraryPath will be build/index.js to go to the common specs we need to go one level up
|
|
13
16
|
const commonSpecPath = _path.default.resolve(libraryPath, '../', 'common');
|
|
14
|
-
const destDirectory = _path.default.resolve(process.cwd(),
|
|
17
|
+
const destDirectory = _path.default.resolve(process.cwd(), _configConstants.default.TEST_SLICE_FOLDER, stage, 'modules', '.testingLib-common');
|
|
15
18
|
(0, _fileUtils.deleteFolder)(destDirectory);
|
|
16
19
|
(0, _fileUtils.copyDirectory)(commonSpecPath, destDirectory);
|
|
17
20
|
}
|