@zohodesk/testinglibrary 0.1.8-stb-bdd-v26 → 0.1.9
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/.babelrc +21 -18
- package/.eslintrc.js +31 -31
- package/.prettierrc +5 -5
- package/README.md +17 -17
- package/bin/cli.js +2 -2
- package/build/bdd-framework/cli/commands/env.js +42 -0
- package/build/bdd-framework/cli/commands/export.js +47 -0
- package/build/bdd-framework/cli/commands/test.js +64 -0
- package/build/bdd-framework/cli/index.js +11 -0
- package/build/bdd-framework/cli/options.js +19 -0
- package/build/bdd-framework/cli/worker.js +13 -0
- package/build/bdd-framework/config/configDir.js +35 -0
- package/build/bdd-framework/config/enrichReporterData.js +23 -0
- package/build/bdd-framework/config/env.js +50 -0
- package/build/bdd-framework/config/index.js +94 -0
- package/build/bdd-framework/config/lang.js +14 -0
- package/build/bdd-framework/cucumber/buildStepDefinition.js +43 -0
- package/build/bdd-framework/cucumber/createTestStep.js +43 -0
- package/build/bdd-framework/cucumber/formatter/EventDataCollector.js +126 -0
- package/build/bdd-framework/cucumber/formatter/GherkinDocumentParser.js +72 -0
- package/build/bdd-framework/cucumber/formatter/PickleParser.js +25 -0
- package/build/bdd-framework/cucumber/formatter/durationHelpers.js +13 -0
- package/build/bdd-framework/cucumber/formatter/getColorFns.js +57 -0
- package/build/bdd-framework/cucumber/formatter/index.js +16 -0
- package/build/bdd-framework/cucumber/formatter/locationHelpers.js +16 -0
- package/build/bdd-framework/cucumber/loadConfig.js +17 -0
- package/build/bdd-framework/cucumber/loadFeatures.js +70 -0
- package/build/bdd-framework/cucumber/loadSnippetBuilder.js +20 -0
- package/build/bdd-framework/cucumber/loadSteps.js +47 -0
- package/build/bdd-framework/cucumber/resolveFeaturePaths.js +62 -0
- package/build/bdd-framework/cucumber/stepArguments.js +21 -0
- package/build/bdd-framework/cucumber/types.js +5 -0
- package/build/bdd-framework/cucumber/valueChecker.js +23 -0
- package/build/bdd-framework/decorators.js +18 -0
- package/build/bdd-framework/gen/fixtures.js +48 -0
- package/build/bdd-framework/gen/formatter.js +123 -0
- package/build/bdd-framework/gen/i18n.js +39 -0
- package/build/bdd-framework/gen/index.js +185 -0
- package/build/bdd-framework/gen/testFile.js +465 -0
- package/build/bdd-framework/gen/testMeta.js +60 -0
- package/build/bdd-framework/gen/testNode.js +60 -0
- package/build/bdd-framework/gen/testPoms.js +133 -0
- package/build/bdd-framework/hooks/scenario.js +130 -0
- package/build/bdd-framework/hooks/worker.js +89 -0
- package/build/bdd-framework/index.js +52 -0
- package/build/bdd-framework/playwright/fixtureParameterNames.js +93 -0
- package/build/bdd-framework/playwright/getLocationInFile.js +79 -0
- package/build/bdd-framework/playwright/loadConfig.js +42 -0
- package/build/bdd-framework/playwright/loadUtils.js +33 -0
- package/build/bdd-framework/playwright/testTypeImpl.js +61 -0
- package/build/bdd-framework/playwright/transform.js +88 -0
- package/build/bdd-framework/playwright/types.js +5 -0
- package/build/bdd-framework/playwright/utils.js +34 -0
- package/build/bdd-framework/reporter/cucumber/base.js +57 -0
- package/build/bdd-framework/reporter/cucumber/custom.js +73 -0
- package/build/bdd-framework/reporter/cucumber/helper.js +12 -0
- package/build/bdd-framework/reporter/cucumber/html.js +35 -0
- package/build/bdd-framework/reporter/cucumber/index.js +74 -0
- package/build/bdd-framework/reporter/cucumber/json.js +312 -0
- package/build/bdd-framework/reporter/cucumber/junit.js +205 -0
- package/build/bdd-framework/reporter/cucumber/message.js +20 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/AttachmentMapper.js +64 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/Builder.js +196 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/GherkinDocument.js +43 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/GherkinDocumentClone.js +52 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/GherkinDocuments.js +105 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/Hook.js +70 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/Meta.js +45 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/Pickles.js +27 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/Projects.js +38 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/TestCase.js +128 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/TestCaseRun.js +126 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/TestCaseRunHooks.js +102 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/TestStepAttachments.js +50 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/TestStepRun.js +88 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/index.js +30 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/pwUtils.js +51 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/timing.js +35 -0
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/types.js +5 -0
- package/build/bdd-framework/run/StepInvoker.js +68 -0
- package/build/bdd-framework/run/bddDataAttachment.js +46 -0
- package/build/bdd-framework/run/bddFixtures.js +191 -0
- package/build/bdd-framework/run/bddWorld.js +79 -0
- package/build/bdd-framework/run/bddWorldInternal.js +15 -0
- package/build/bdd-framework/snippets/index.js +132 -0
- package/build/bdd-framework/snippets/snippetSyntax.js +43 -0
- package/build/bdd-framework/snippets/snippetSyntaxDecorators.js +26 -0
- package/build/bdd-framework/snippets/snippetSyntaxTs.js +18 -0
- package/build/bdd-framework/stepDefinitions/createBdd.js +66 -0
- package/build/bdd-framework/stepDefinitions/decorators/class.js +68 -0
- package/build/bdd-framework/stepDefinitions/decorators/steps.js +99 -0
- package/build/bdd-framework/stepDefinitions/defineStep.js +62 -0
- package/build/bdd-framework/stepDefinitions/stepConfig.js +24 -0
- package/build/bdd-framework/utils/AutofillMap.js +20 -0
- package/build/bdd-framework/utils/exit.js +62 -0
- package/build/bdd-framework/utils/index.js +93 -0
- package/build/bdd-framework/utils/jsStringWrap.js +44 -0
- package/build/bdd-framework/utils/logger.js +30 -0
- package/build/bdd-framework/utils/stripAnsiEscapes.js +20 -0
- package/build/core/playwright/builtInFixtures/addTags.js +1 -1
- package/build/core/playwright/builtInFixtures/context.js +18 -1
- package/build/core/playwright/builtInFixtures/i18N.js +33 -0
- package/build/core/playwright/builtInFixtures/index.js +19 -7
- package/build/core/playwright/builtInFixtures/page.js +69 -39
- package/build/core/playwright/builtInFixtures/unauthenticatedPage.js +18 -0
- package/build/core/playwright/clear-caches.js +19 -8
- package/build/core/playwright/codegen.js +4 -4
- package/build/core/playwright/constants/browserTypes.js +12 -0
- package/build/core/playwright/custom-commands.js +1 -1
- package/build/core/playwright/env-initializer.js +10 -6
- package/build/core/playwright/helpers/auth/accountLogin.js +18 -0
- package/build/core/playwright/helpers/auth/checkAuthCookies.js +47 -0
- package/build/core/playwright/helpers/auth/getUrlOrigin.js +13 -0
- package/build/core/playwright/helpers/auth/getUsers.js +72 -0
- package/build/core/playwright/helpers/auth/index.js +58 -0
- package/build/core/playwright/helpers/auth/loginSteps.js +36 -0
- package/build/core/playwright/helpers/configFileNameProvider.js +17 -0
- package/build/core/playwright/helpers/getUserFixtures.js +23 -0
- package/build/core/playwright/helpers/mergeObjects.js +13 -0
- package/build/core/playwright/helpers/parseUserArgs.js +11 -0
- package/build/core/playwright/index.js +69 -15
- package/build/core/playwright/readConfigFile.js +50 -39
- package/build/core/playwright/report-generator.js +7 -7
- package/build/core/playwright/setup/config-creator.js +15 -16
- package/build/core/playwright/setup/config-utils.js +60 -26
- package/build/core/playwright/setup/custom-reporter.js +3 -2
- package/build/core/playwright/tag-processor.js +12 -23
- package/build/core/playwright/test-runner.js +49 -63
- package/build/core/playwright/types.js +43 -0
- package/build/decorators.d.ts +1 -1
- package/build/decorators.js +16 -2
- package/build/index.d.ts +79 -12
- package/build/index.js +51 -9
- package/build/lib/cli.js +12 -3
- package/build/lib/post-install.js +18 -10
- package/build/parser/sample.feature +34 -34
- package/build/parser/sample.spec.js +18 -18
- package/build/setup-folder-structure/helper.js +3 -0
- package/build/setup-folder-structure/reportEnhancement/addonScript.html +24 -24
- package/build/setup-folder-structure/samples/auth-setup-sample.js +72 -72
- package/build/setup-folder-structure/samples/authUsers-sample.json +8 -8
- package/build/setup-folder-structure/samples/env-config-sample.json +20 -20
- package/build/setup-folder-structure/samples/git-ignore.sample.js +36 -36
- package/build/setup-folder-structure/samples/uat-config-sample.js +44 -44
- package/build/utils/cliArgsToObject.js +30 -26
- package/build/utils/fileUtils.js +4 -19
- package/build/utils/getFilePath.js +1 -2
- package/build/utils/rootPath.js +16 -9
- package/changelog.md +144 -131
- package/jest.config.js +63 -63
- package/npm-shrinkwrap.json +6475 -5994
- package/package.json +57 -56
- package/playwright.config.js +112 -112
- package/build/bdd-poc/config/pathConfig.js +0 -22
- package/build/bdd-poc/core-runner/exportMethods.js +0 -22
- package/build/bdd-poc/core-runner/main.js +0 -15
- package/build/bdd-poc/core-runner/stepDefinitions.js +0 -157
- package/build/bdd-poc/core-runner/stepRunner.js +0 -25
- package/build/bdd-poc/errors/throwError.js +0 -23
- package/build/bdd-poc/index.js +0 -26
- package/build/bdd-poc/test/cucumber/featureFileParer.js +0 -84
- package/build/bdd-poc/test/cucumber/parserCucumber.js +0 -15
- package/build/bdd-poc/test/stepGenerate/extractTestInputs.js +0 -65
- package/build/bdd-poc/test/stepGenerate/parserSteps.js +0 -81
- package/build/bdd-poc/test/stepGenerate/stepFileGenerate.js +0 -40
- package/build/bdd-poc/test/stepGenerate/stepsnippets.js +0 -61
- package/build/bdd-poc/test/tagsHandle.js +0 -70
- package/build/bdd-poc/test/testData.js +0 -125
- package/build/bdd-poc/test/testStructure.js +0 -92
- package/build/bdd-poc/utils/stringManipulation.js +0 -26
|
@@ -1,51 +1,81 @@
|
|
|
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;
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
8
|
+
var _getUsers = require("../helpers/auth/getUsers");
|
|
9
|
+
var _loginSteps = _interopRequireDefault(require("../helpers/auth/loginSteps"));
|
|
10
|
+
var _readConfigFile = require("../readConfigFile");
|
|
11
|
+
/* eslint-disable global-require */
|
|
12
|
+
|
|
13
|
+
function getTagInputFromSelectedTags(tags, inputString) {
|
|
14
|
+
const selectedTag = tags.find(tag => tag.startsWith(inputString));
|
|
15
|
+
let tagInput = null;
|
|
16
|
+
if (selectedTag) {
|
|
17
|
+
tagInput = selectedTag.split(`${inputString}_`).pop().toLowerCase();
|
|
18
|
+
}
|
|
19
|
+
return tagInput;
|
|
20
|
+
}
|
|
21
|
+
function getCustomAccountDetails(tags) {
|
|
22
|
+
const filteredTags = tags.filter(tag => tag.startsWith('@profile') || tag.startsWith('@edition') || tag.startsWith('@profile') || tag.startsWith('@darkLaunch'));
|
|
23
|
+
if (filteredTags && filteredTags.length > 0) {
|
|
24
|
+
const selectedProfile = getTagInputFromSelectedTags(filteredTags, '@profile');
|
|
25
|
+
const selectedEdition = getTagInputFromSelectedTags(filteredTags, '@edition');
|
|
26
|
+
const darkLaunchFeature = getTagInputFromSelectedTags(filteredTags, '@darkLaunch');
|
|
27
|
+
const user = (0, _getUsers.getUserForSelectedEditionAndProfile)(selectedEdition, selectedProfile, darkLaunchFeature);
|
|
28
|
+
return user;
|
|
29
|
+
}
|
|
30
|
+
return null;
|
|
31
|
+
}
|
|
32
|
+
const {
|
|
33
|
+
testSetup
|
|
34
|
+
} = (0, _readConfigFile.generateConfigFromFile)();
|
|
35
|
+
async function performDefaultPageSteps({
|
|
36
|
+
context,
|
|
37
|
+
$tags,
|
|
38
|
+
page
|
|
39
|
+
}) {
|
|
40
|
+
if (testSetup.page && typeof testSetup.page === 'function') {
|
|
41
|
+
await testSetup.page({
|
|
42
|
+
context,
|
|
43
|
+
$tags,
|
|
44
|
+
page
|
|
45
|
+
});
|
|
46
|
+
} else {
|
|
47
|
+
await page.goto(process.env.domain);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
33
50
|
var _default = exports.default = {
|
|
34
51
|
page: async ({
|
|
52
|
+
context,
|
|
53
|
+
$tags,
|
|
35
54
|
page
|
|
36
55
|
}, use) => {
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
56
|
+
const customAccountDetails = getCustomAccountDetails($tags);
|
|
57
|
+
if (customAccountDetails === null) {
|
|
58
|
+
await performDefaultPageSteps({
|
|
59
|
+
context,
|
|
60
|
+
$tags,
|
|
61
|
+
page
|
|
62
|
+
});
|
|
63
|
+
await use(page);
|
|
64
|
+
} else {
|
|
65
|
+
await context.clearCookies();
|
|
66
|
+
await (0, _loginSteps.default)({
|
|
67
|
+
page,
|
|
68
|
+
role: `${customAccountDetails.role}-${customAccountDetails.edition}`,
|
|
69
|
+
useremail: customAccountDetails.email,
|
|
70
|
+
password: customAccountDetails.password
|
|
71
|
+
}, async () => page.url().includes(process.env.domain));
|
|
72
|
+
await performDefaultPageSteps({
|
|
73
|
+
context,
|
|
74
|
+
$tags,
|
|
75
|
+
page
|
|
76
|
+
});
|
|
77
|
+
await use(page);
|
|
78
|
+
await context.close();
|
|
79
|
+
}
|
|
50
80
|
}
|
|
51
81
|
};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var _default = exports.default = {
|
|
8
|
+
unauthenticatedPage: async ({
|
|
9
|
+
browser
|
|
10
|
+
}, use) => {
|
|
11
|
+
const context = await browser.newContext({
|
|
12
|
+
storageState: null
|
|
13
|
+
});
|
|
14
|
+
const unauthenticatedPage = await context.newPage();
|
|
15
|
+
await use(unauthenticatedPage);
|
|
16
|
+
await context.close();
|
|
17
|
+
}
|
|
18
|
+
};
|
|
@@ -9,21 +9,32 @@ var _path = _interopRequireDefault(require("path"));
|
|
|
9
9
|
var _fileUtils = require("../../utils/fileUtils");
|
|
10
10
|
var _logger = require("../../utils/logger");
|
|
11
11
|
var _readConfigFile = require("./readConfigFile");
|
|
12
|
+
function deleteAuthFiles(authFilePath) {
|
|
13
|
+
authFilePath.split('/').pop();
|
|
14
|
+
_logger.Logger.log(_logger.Logger.INFO_TYPE, `Deleting auth files present in ${authFilePath}`);
|
|
15
|
+
(0, _fileUtils.deleteFolder)(_path.default.resolve(process.cwd(), authFilePath));
|
|
16
|
+
}
|
|
17
|
+
function deletePlaywrightReport(reportPath) {
|
|
18
|
+
_logger.Logger.log(_logger.Logger.INFO_TYPE, `Deleting Playwright report ${reportPath}`);
|
|
19
|
+
(0, _fileUtils.deleteFolder)(reportPath);
|
|
20
|
+
}
|
|
21
|
+
function deleteGeneratedFeatures() {
|
|
22
|
+
const featuresGenPath = _path.default.resolve(process.cwd(), 'uat', '.features-gen');
|
|
23
|
+
_logger.Logger.log(_logger.Logger.INFO_TYPE, `Deleting generated features at ${featuresGenPath}`);
|
|
24
|
+
(0, _fileUtils.deleteFolder)(featuresGenPath);
|
|
25
|
+
}
|
|
12
26
|
function clearCaches() {
|
|
13
27
|
try {
|
|
14
28
|
const {
|
|
15
29
|
authFilePath,
|
|
16
30
|
reportPath
|
|
17
31
|
} = (0, _readConfigFile.generateConfigFromFile)();
|
|
18
|
-
authFilePath
|
|
19
|
-
|
|
20
|
-
(
|
|
21
|
-
_logger.Logger.log(_logger.Logger.
|
|
22
|
-
(0, _fileUtils.deleteFolder)(reportPath);
|
|
23
|
-
(0, _fileUtils.deleteFolder)(_path.default.resolve(process.cwd(), 'uat', '.features-gen'));
|
|
24
|
-
_logger.Logger.log(_logger.Logger.SUCCESS_TYPE, 'Caches Cleared');
|
|
32
|
+
deleteAuthFiles(authFilePath);
|
|
33
|
+
deletePlaywrightReport(reportPath);
|
|
34
|
+
deleteGeneratedFeatures();
|
|
35
|
+
_logger.Logger.log(_logger.Logger.SUCCESS_TYPE, 'Caches Cleared. Now you can try running npm run uat');
|
|
25
36
|
} catch (err) {
|
|
26
|
-
_logger.Logger.log(_logger.Logger.FAILURE_TYPE, 'Error While clearing cookies');
|
|
37
|
+
_logger.Logger.log(_logger.Logger.FAILURE_TYPE, 'Error While clearing cookies. Try manually delete folder uat/playwright and uat/playwright-report');
|
|
27
38
|
}
|
|
28
39
|
}
|
|
29
40
|
var _default = exports.default = clearCaches;
|
|
@@ -9,11 +9,11 @@ var _child_process = require("child_process");
|
|
|
9
9
|
var _path = _interopRequireDefault(require("path"));
|
|
10
10
|
var _logger = require("../../utils/logger");
|
|
11
11
|
var _rootPath = require("../../utils/rootPath");
|
|
12
|
-
const userArgs = process.argv.slice(3);
|
|
13
|
-
const playwrightPath = _path.default.resolve((0, _rootPath.getExecutableBinaryPath)('playwright'));
|
|
14
|
-
const command = playwrightPath;
|
|
15
|
-
const args = ['codegen'].concat(userArgs);
|
|
16
12
|
function generateCodegen() {
|
|
13
|
+
const domainUrl = process.argv.slice(3);
|
|
14
|
+
const playwrightPath = _path.default.resolve((0, _rootPath.getExecutableBinaryPath)('playwright'));
|
|
15
|
+
const command = playwrightPath;
|
|
16
|
+
const args = ['codegen'].concat(domainUrl);
|
|
17
17
|
const childProcess = (0, _child_process.spawn)(command, args, {
|
|
18
18
|
stdio: 'inherit'
|
|
19
19
|
});
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.BROWSER_PROJECT_MAPPING = void 0;
|
|
7
|
+
const BROWSER_PROJECT_MAPPING = exports.BROWSER_PROJECT_MAPPING = {
|
|
8
|
+
CHROME: 'chromium',
|
|
9
|
+
EDGE: 'Microsoft Edge',
|
|
10
|
+
FIREFOX: 'firefox',
|
|
11
|
+
SAFARI: 'webkit'
|
|
12
|
+
};
|
|
@@ -4,4 +4,4 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.CUSTOM_COMMANDS = void 0;
|
|
7
|
-
const CUSTOM_COMMANDS = exports.CUSTOM_COMMANDS = ['mode', 'tags', 'edition'];
|
|
7
|
+
const CUSTOM_COMMANDS = exports.CUSTOM_COMMANDS = ['mode', 'tags', 'edition', 'browsers', 'filePath'];
|
|
@@ -7,15 +7,19 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
7
7
|
exports.initializeEnvConfig = initializeEnvConfig;
|
|
8
8
|
var _fs = require("fs");
|
|
9
9
|
var _path = _interopRequireDefault(require("path"));
|
|
10
|
+
var _configFileNameProvider = require("./helpers/configFileNameProvider");
|
|
11
|
+
function setEnvironmentVariables(mode, configJSON) {
|
|
12
|
+
process.env.mode = mode;
|
|
13
|
+
for (const key in configJSON[mode]) {
|
|
14
|
+
process.env[key] = configJSON[mode][key];
|
|
15
|
+
}
|
|
16
|
+
}
|
|
10
17
|
function initializeEnvConfig(mode = 'dev') {
|
|
11
18
|
try {
|
|
12
|
-
const configFile = (0, _fs.readFileSync)(_path.default.resolve(process.cwd(),
|
|
19
|
+
const configFile = (0, _fs.readFileSync)(_path.default.resolve(process.cwd(), `./${(0, _configFileNameProvider.getEnvConfigFilePath)()}`));
|
|
13
20
|
const configJSON = JSON.parse(configFile);
|
|
14
|
-
|
|
15
|
-
for (const key in configJSON[mode]) {
|
|
16
|
-
process.env[key] = configJSON[mode][key];
|
|
17
|
-
}
|
|
21
|
+
setEnvironmentVariables(mode, configJSON);
|
|
18
22
|
} catch (err) {
|
|
19
|
-
throw new Error(
|
|
23
|
+
throw new Error(`Config File Not Exists. Please provide a config file ${(0, _configFileNameProvider.getEnvConfigFilePath)()} to intiailize the environment variables`);
|
|
20
24
|
}
|
|
21
25
|
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = void 0;
|
|
8
|
+
var _getUrlOrigin = _interopRequireDefault(require("./getUrlOrigin"));
|
|
9
|
+
async function accountLogin(page, useremail, password) {
|
|
10
|
+
await page.locator('#login_id').fill(useremail);
|
|
11
|
+
await page.locator('#nextbtn').click();
|
|
12
|
+
await page.locator('#password').fill(password);
|
|
13
|
+
await page.locator('#nextbtn').click();
|
|
14
|
+
const domainUrlOrigin = (0, _getUrlOrigin.default)(process.env.domain);
|
|
15
|
+
await page.waitForNavigation();
|
|
16
|
+
await Promise.race([page.waitForURL(`${domainUrlOrigin}/**`), page.waitForURL('**/announcement/**')]);
|
|
17
|
+
}
|
|
18
|
+
var _default = exports.default = accountLogin;
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.authDirectory = void 0;
|
|
8
|
+
exports.loadCookiesIfPresent = loadCookiesIfPresent;
|
|
9
|
+
exports.verifyIfCookieFileExists = verifyIfCookieFileExists;
|
|
10
|
+
var _path = _interopRequireDefault(require("path"));
|
|
11
|
+
var _fs = require("fs");
|
|
12
|
+
var _readConfigFile = require("../../readConfigFile");
|
|
13
|
+
/* eslint-disable no-console */
|
|
14
|
+
|
|
15
|
+
const {
|
|
16
|
+
uatDirectory
|
|
17
|
+
} = (0, _readConfigFile.generateConfigFromFile)();
|
|
18
|
+
const authDirectory = exports.authDirectory = _path.default.resolve(_path.default.join(uatDirectory, 'playwright', '.auth'));
|
|
19
|
+
const authContent = {
|
|
20
|
+
cookies: []
|
|
21
|
+
};
|
|
22
|
+
function verifyIfCookieFileExists(authFile) {
|
|
23
|
+
if (!(0, _fs.existsSync)(authDirectory)) {
|
|
24
|
+
console.log('Creating auth directory for the first time setup...');
|
|
25
|
+
(0, _fs.mkdirSync)(authDirectory, {
|
|
26
|
+
recursive: true
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
if (!(0, _fs.existsSync)(authFile)) {
|
|
30
|
+
console.log('creating auth file..');
|
|
31
|
+
(0, _fs.writeFileSync)(authFile, JSON.stringify(authContent, null, 2));
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
function convertCookiesToParse(cookies, authFilePath) {
|
|
35
|
+
try {
|
|
36
|
+
return JSON.parse(cookies);
|
|
37
|
+
} catch (err) {
|
|
38
|
+
throw new Error(` Error while parsing cookies ${err} \n${_path.default.resolve(process.cwd(), authFilePath)} File is Empty`);
|
|
39
|
+
// process.exit()
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
async function loadCookiesIfPresent(page, authFile) {
|
|
43
|
+
verifyIfCookieFileExists(authFile);
|
|
44
|
+
const cookies = (0, _fs.readFileSync)(authFile);
|
|
45
|
+
const parsedCookies = convertCookiesToParse(cookies, authFile);
|
|
46
|
+
await page.context().addCookies(parsedCookies.cookies === undefined ? [] : parsedCookies.cookies);
|
|
47
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
function getUrlOrigin(url) {
|
|
8
|
+
const {
|
|
9
|
+
origin
|
|
10
|
+
} = new URL(url);
|
|
11
|
+
return origin;
|
|
12
|
+
}
|
|
13
|
+
var _default = exports.default = getUrlOrigin;
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.getListOfUsers = getListOfUsers;
|
|
8
|
+
exports.getPrimaryUser = getPrimaryUser;
|
|
9
|
+
exports.getUserForSelectedEditionAndProfile = getUserForSelectedEditionAndProfile;
|
|
10
|
+
exports.isCI = isCI;
|
|
11
|
+
var _path = _interopRequireDefault(require("path"));
|
|
12
|
+
var _readConfigFile = require("../../readConfigFile");
|
|
13
|
+
/* eslint-disable global-require */
|
|
14
|
+
function isCI() {
|
|
15
|
+
return process.env.mode === 'CI' || process.env.mode === 'ci';
|
|
16
|
+
}
|
|
17
|
+
function getListOfUsers() {
|
|
18
|
+
let users;
|
|
19
|
+
const {
|
|
20
|
+
uatDirectory
|
|
21
|
+
} = (0, _readConfigFile.generateConfigFromFile)();
|
|
22
|
+
if (isCI()) {
|
|
23
|
+
users = require(_path.default.join(uatDirectory, 'conf/ci/actors/index'));
|
|
24
|
+
} else {
|
|
25
|
+
users = require(_path.default.join(uatDirectory, 'conf/dev/actors/index'));
|
|
26
|
+
}
|
|
27
|
+
return users;
|
|
28
|
+
}
|
|
29
|
+
function getPrimaryUser() {
|
|
30
|
+
let primaryUser;
|
|
31
|
+
const {
|
|
32
|
+
uatDirectory
|
|
33
|
+
} = (0, _readConfigFile.generateConfigFromFile)();
|
|
34
|
+
if (isCI()) {
|
|
35
|
+
primaryUser = require(_path.default.join(uatDirectory, 'conf/ci/settings.json'));
|
|
36
|
+
} else {
|
|
37
|
+
primaryUser = require(_path.default.join(uatDirectory, 'conf/dev/settings.json'));
|
|
38
|
+
}
|
|
39
|
+
return primaryUser;
|
|
40
|
+
}
|
|
41
|
+
function getUserForSelectedEditionAndProfile(preferedEdition, preferredProfile, darkLaunchFeature) {
|
|
42
|
+
const {
|
|
43
|
+
editions: userdata,
|
|
44
|
+
darkLaunch
|
|
45
|
+
} = getListOfUsers();
|
|
46
|
+
const primaryUser = getPrimaryUser();
|
|
47
|
+
const edition = preferedEdition || primaryUser.edition;
|
|
48
|
+
const profile = preferredProfile || primaryUser.role;
|
|
49
|
+
let selectedProfile = {};
|
|
50
|
+
if (darkLaunchFeature && darkLaunchFeature !== null) {
|
|
51
|
+
const {
|
|
52
|
+
profiles: darkLaunchProfiles,
|
|
53
|
+
...darkLaunchEditionData
|
|
54
|
+
} = darkLaunch[darkLaunchFeature] ? darkLaunch[darkLaunchFeature][0] : {};
|
|
55
|
+
selectedProfile = darkLaunchProfiles.find(user => user.role === profile);
|
|
56
|
+
return {
|
|
57
|
+
...darkLaunchEditionData,
|
|
58
|
+
...selectedProfile
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
// TODO: We are returning the first data from array. We need to check the possiblity of having multiple users for same role and possibly round robin
|
|
62
|
+
// For this we need to get the data from ci environment.
|
|
63
|
+
const {
|
|
64
|
+
profiles,
|
|
65
|
+
...editionData
|
|
66
|
+
} = userdata[edition] ? userdata[edition][0] : {};
|
|
67
|
+
selectedProfile = profiles.find(user => user.role === profile);
|
|
68
|
+
return {
|
|
69
|
+
...editionData,
|
|
70
|
+
...selectedProfile
|
|
71
|
+
};
|
|
72
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
Object.defineProperty(exports, "accountLogin", {
|
|
8
|
+
enumerable: true,
|
|
9
|
+
get: function () {
|
|
10
|
+
return _accountLogin.default;
|
|
11
|
+
}
|
|
12
|
+
});
|
|
13
|
+
Object.defineProperty(exports, "getListOfUsers", {
|
|
14
|
+
enumerable: true,
|
|
15
|
+
get: function () {
|
|
16
|
+
return _getUsers.getListOfUsers;
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
Object.defineProperty(exports, "getPrimaryUser", {
|
|
20
|
+
enumerable: true,
|
|
21
|
+
get: function () {
|
|
22
|
+
return _getUsers.getPrimaryUser;
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
Object.defineProperty(exports, "getUserForSelectedEditionAndProfile", {
|
|
26
|
+
enumerable: true,
|
|
27
|
+
get: function () {
|
|
28
|
+
return _getUsers.getUserForSelectedEditionAndProfile;
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
Object.defineProperty(exports, "isCI", {
|
|
32
|
+
enumerable: true,
|
|
33
|
+
get: function () {
|
|
34
|
+
return _getUsers.isCI;
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
Object.defineProperty(exports, "loadCookiesIfPresent", {
|
|
38
|
+
enumerable: true,
|
|
39
|
+
get: function () {
|
|
40
|
+
return _checkAuthCookies.loadCookiesIfPresent;
|
|
41
|
+
}
|
|
42
|
+
});
|
|
43
|
+
Object.defineProperty(exports, "performLoginSteps", {
|
|
44
|
+
enumerable: true,
|
|
45
|
+
get: function () {
|
|
46
|
+
return _loginSteps.default;
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
Object.defineProperty(exports, "verifyIfCookieFileExists", {
|
|
50
|
+
enumerable: true,
|
|
51
|
+
get: function () {
|
|
52
|
+
return _checkAuthCookies.verifyIfCookieFileExists;
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
var _accountLogin = _interopRequireDefault(require("./accountLogin"));
|
|
56
|
+
var _checkAuthCookies = require("./checkAuthCookies");
|
|
57
|
+
var _getUsers = require("./getUsers");
|
|
58
|
+
var _loginSteps = _interopRequireDefault(require("./loginSteps"));
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = void 0;
|
|
8
|
+
var _path = _interopRequireDefault(require("path"));
|
|
9
|
+
var _accountLogin = _interopRequireDefault(require("./accountLogin"));
|
|
10
|
+
var _checkAuthCookies = require("./checkAuthCookies");
|
|
11
|
+
/* eslint-disable no-console */
|
|
12
|
+
|
|
13
|
+
async function performLoginSteps({
|
|
14
|
+
page,
|
|
15
|
+
role,
|
|
16
|
+
useremail,
|
|
17
|
+
password
|
|
18
|
+
}, isLoggedIn) {
|
|
19
|
+
const authFile = _path.default.resolve(_path.default.join(_checkAuthCookies.authDirectory, `${role}-cookies.json`));
|
|
20
|
+
await (0, _checkAuthCookies.loadCookiesIfPresent)(page, authFile);
|
|
21
|
+
await page.goto(process.env.domain);
|
|
22
|
+
await page.waitForNavigation();
|
|
23
|
+
const loginStatus = await isLoggedIn(page);
|
|
24
|
+
if (!loginStatus) {
|
|
25
|
+
await (0, _accountLogin.default)(page, useremail, password);
|
|
26
|
+
await page.goto(process.env.domain);
|
|
27
|
+
|
|
28
|
+
// await page.waitForLoadState();
|
|
29
|
+
|
|
30
|
+
await isLoggedIn(page);
|
|
31
|
+
await page.context().storageState({
|
|
32
|
+
path: authFile
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
var _default = exports.default = performLoginSteps;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.getEnvConfigFilePath = getEnvConfigFilePath;
|
|
7
|
+
exports.getReportFileName = getReportFileName;
|
|
8
|
+
exports.getUATFileName = getUATFileName;
|
|
9
|
+
function getUATFileName() {
|
|
10
|
+
return 'uat.config.js';
|
|
11
|
+
}
|
|
12
|
+
function getEnvConfigFilePath() {
|
|
13
|
+
return `uat/env-config.json`;
|
|
14
|
+
}
|
|
15
|
+
function getReportFileName() {
|
|
16
|
+
return `test-summary.json`;
|
|
17
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var _logger = require("../../../utils/logger");
|
|
8
|
+
var _readConfigFile = require("../readConfigFile");
|
|
9
|
+
function getUserFixtures() {
|
|
10
|
+
const {
|
|
11
|
+
additionalPages
|
|
12
|
+
} = (0, _readConfigFile.generateConfigFromFile)();
|
|
13
|
+
|
|
14
|
+
// if (additionalPages.page || additionalPages.context) {
|
|
15
|
+
// // Logger.log(
|
|
16
|
+
// // Logger.INFO_TYPE,
|
|
17
|
+
// // 'Not allowed to override the page and context fixture. Use Test Setup in uat configuration'
|
|
18
|
+
// // );
|
|
19
|
+
// }
|
|
20
|
+
|
|
21
|
+
return additionalPages;
|
|
22
|
+
}
|
|
23
|
+
var _default = exports.default = getUserFixtures;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.mergeObjects = mergeObjects;
|
|
7
|
+
// Utility function to merge objects using spread operator
|
|
8
|
+
function mergeObjects(obj1, obj2) {
|
|
9
|
+
return {
|
|
10
|
+
...obj1,
|
|
11
|
+
...obj2
|
|
12
|
+
};
|
|
13
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var _cliArgsToObject = require("../../../utils/cliArgsToObject");
|
|
8
|
+
function parseUserArgs() {
|
|
9
|
+
return (0, _cliArgsToObject.cliArgsToObject)(process.argv.slice(2));
|
|
10
|
+
}
|
|
11
|
+
var _default = exports.default = parseUserArgs;
|
|
@@ -4,35 +4,89 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
4
4
|
Object.defineProperty(exports, "__esModule", {
|
|
5
5
|
value: true
|
|
6
6
|
});
|
|
7
|
+
exports.When = exports.Then = exports.Given = void 0;
|
|
8
|
+
Object.defineProperty(exports, "accountLogin", {
|
|
9
|
+
enumerable: true,
|
|
10
|
+
get: function () {
|
|
11
|
+
return _index.accountLogin;
|
|
12
|
+
}
|
|
13
|
+
});
|
|
14
|
+
Object.defineProperty(exports, "createBdd", {
|
|
15
|
+
enumerable: true,
|
|
16
|
+
get: function () {
|
|
17
|
+
return _bddFramework.createBdd;
|
|
18
|
+
}
|
|
19
|
+
});
|
|
7
20
|
Object.defineProperty(exports, "expect", {
|
|
8
21
|
enumerable: true,
|
|
9
22
|
get: function () {
|
|
10
23
|
return _test.expect;
|
|
11
24
|
}
|
|
12
25
|
});
|
|
26
|
+
Object.defineProperty(exports, "getListOfUsers", {
|
|
27
|
+
enumerable: true,
|
|
28
|
+
get: function () {
|
|
29
|
+
return _index.getListOfUsers;
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
Object.defineProperty(exports, "getPrimaryUser", {
|
|
33
|
+
enumerable: true,
|
|
34
|
+
get: function () {
|
|
35
|
+
return _index.getPrimaryUser;
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
Object.defineProperty(exports, "getUserForSelectedEditionAndProfile", {
|
|
39
|
+
enumerable: true,
|
|
40
|
+
get: function () {
|
|
41
|
+
return _index.getUserForSelectedEditionAndProfile;
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
Object.defineProperty(exports, "isCI", {
|
|
45
|
+
enumerable: true,
|
|
46
|
+
get: function () {
|
|
47
|
+
return _index.isCI;
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
Object.defineProperty(exports, "loadCookiesIfPresent", {
|
|
51
|
+
enumerable: true,
|
|
52
|
+
get: function () {
|
|
53
|
+
return _index.loadCookiesIfPresent;
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
Object.defineProperty(exports, "performLoginSteps", {
|
|
57
|
+
enumerable: true,
|
|
58
|
+
get: function () {
|
|
59
|
+
return _index.performLoginSteps;
|
|
60
|
+
}
|
|
61
|
+
});
|
|
13
62
|
exports.test = void 0;
|
|
63
|
+
Object.defineProperty(exports, "verifyIfCookieFileExists", {
|
|
64
|
+
enumerable: true,
|
|
65
|
+
get: function () {
|
|
66
|
+
return _index.verifyIfCookieFileExists;
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
var _bddFramework = require("../../bdd-framework");
|
|
14
70
|
var _test = require("@playwright/test");
|
|
15
71
|
var _readConfigFile = require("./readConfigFile");
|
|
16
72
|
var _builtInFixtures = _interopRequireDefault(require("./builtInFixtures"));
|
|
17
|
-
|
|
18
|
-
|
|
73
|
+
var _index = require("./helpers/auth/index");
|
|
74
|
+
var _getUserFixtures = _interopRequireDefault(require("./helpers/getUserFixtures"));
|
|
19
75
|
const {
|
|
20
|
-
additionalPages: userFixtures,
|
|
21
76
|
bddMode
|
|
22
77
|
} = (0, _readConfigFile.generateConfigFromFile)();
|
|
23
|
-
|
|
24
|
-
let base = _test.test;
|
|
78
|
+
let base = bddMode ? _bddFramework.test : _test.test;
|
|
25
79
|
const buildInFixtures = (0, _builtInFixtures.default)(bddMode);
|
|
26
|
-
|
|
27
|
-
if (!bddMode) {
|
|
28
|
-
$customFixtures = {
|
|
29
|
-
$tags: ({}, use) => use([])
|
|
30
|
-
};
|
|
31
|
-
}
|
|
80
|
+
const userFixtures = (0, _getUserFixtures.default)();
|
|
32
81
|
const test = exports.test = base.extend({
|
|
33
82
|
...buildInFixtures,
|
|
34
|
-
...userFixtures
|
|
35
|
-
...$customFixtures
|
|
83
|
+
...userFixtures
|
|
36
84
|
});
|
|
37
|
-
|
|
38
|
-
|
|
85
|
+
const {
|
|
86
|
+
Given,
|
|
87
|
+
When,
|
|
88
|
+
Then
|
|
89
|
+
} = (0, _bddFramework.createBdd)();
|
|
90
|
+
exports.Then = Then;
|
|
91
|
+
exports.When = When;
|
|
92
|
+
exports.Given = Given;
|