@zohodesk/testinglibrary 0.4.57-n18-experimental → 0.4.58

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 (139) hide show
  1. package/.gitlab-ci.yml +32 -2
  2. package/README.md +1 -54
  3. package/build/bdd-framework/cli/commands/env.js +42 -0
  4. package/build/bdd-framework/cli/commands/export.js +62 -0
  5. package/build/bdd-framework/cli/commands/test.js +64 -0
  6. package/build/bdd-framework/cli/index.js +11 -0
  7. package/build/bdd-framework/cli/options.js +19 -0
  8. package/build/bdd-framework/cli/worker.js +13 -0
  9. package/build/bdd-framework/config/configDir.js +35 -0
  10. package/build/bdd-framework/config/enrichReporterData.js +23 -0
  11. package/build/bdd-framework/config/env.js +50 -0
  12. package/build/bdd-framework/config/index.js +94 -0
  13. package/build/bdd-framework/config/lang.js +14 -0
  14. package/build/bdd-framework/cucumber/buildStepDefinition.js +43 -0
  15. package/build/bdd-framework/cucumber/createTestStep.js +43 -0
  16. package/build/bdd-framework/cucumber/formatter/EventDataCollector.js +125 -0
  17. package/build/bdd-framework/cucumber/formatter/GherkinDocumentParser.js +72 -0
  18. package/build/bdd-framework/cucumber/formatter/PickleParser.js +25 -0
  19. package/build/bdd-framework/cucumber/formatter/durationHelpers.js +13 -0
  20. package/build/bdd-framework/cucumber/formatter/getColorFns.js +57 -0
  21. package/build/bdd-framework/cucumber/formatter/index.js +16 -0
  22. package/build/bdd-framework/cucumber/formatter/locationHelpers.js +16 -0
  23. package/build/bdd-framework/cucumber/loadConfig.js +17 -0
  24. package/build/bdd-framework/cucumber/loadFeatures.js +70 -0
  25. package/build/bdd-framework/cucumber/loadSnippetBuilder.js +20 -0
  26. package/build/bdd-framework/cucumber/loadSteps.js +47 -0
  27. package/build/bdd-framework/cucumber/resolveFeaturePaths.js +62 -0
  28. package/build/bdd-framework/cucumber/stepArguments.js +21 -0
  29. package/build/bdd-framework/cucumber/types.js +5 -0
  30. package/build/bdd-framework/cucumber/valueChecker.js +23 -0
  31. package/build/bdd-framework/decorators.js +18 -0
  32. package/build/bdd-framework/gen/fixtures.js +48 -0
  33. package/build/bdd-framework/gen/formatter.js +167 -0
  34. package/build/bdd-framework/gen/i18n.js +39 -0
  35. package/build/bdd-framework/gen/index.js +197 -0
  36. package/build/bdd-framework/gen/specialTags.js +70 -0
  37. package/build/bdd-framework/gen/testFile.js +470 -0
  38. package/build/bdd-framework/gen/testMeta.js +60 -0
  39. package/build/bdd-framework/gen/testNode.js +35 -0
  40. package/build/bdd-framework/gen/testPoms.js +133 -0
  41. package/build/bdd-framework/hooks/scenario.js +130 -0
  42. package/build/bdd-framework/hooks/worker.js +89 -0
  43. package/build/bdd-framework/index.js +52 -0
  44. package/build/bdd-framework/playwright/fixtureParameterNames.js +93 -0
  45. package/build/bdd-framework/playwright/getLocationInFile.js +79 -0
  46. package/build/bdd-framework/playwright/loadConfig.js +42 -0
  47. package/build/bdd-framework/playwright/loadUtils.js +33 -0
  48. package/build/bdd-framework/playwright/testTypeImpl.js +79 -0
  49. package/build/bdd-framework/playwright/transform.js +88 -0
  50. package/build/bdd-framework/playwright/types.js +12 -0
  51. package/build/bdd-framework/playwright/utils.js +56 -0
  52. package/build/bdd-framework/reporter/cucumber/base.js +52 -0
  53. package/build/bdd-framework/reporter/cucumber/custom.js +73 -0
  54. package/build/bdd-framework/reporter/cucumber/helper.js +12 -0
  55. package/build/bdd-framework/reporter/cucumber/html.js +40 -0
  56. package/build/bdd-framework/reporter/cucumber/index.js +74 -0
  57. package/build/bdd-framework/reporter/cucumber/json.js +311 -0
  58. package/build/bdd-framework/reporter/cucumber/junit.js +205 -0
  59. package/build/bdd-framework/reporter/cucumber/message.js +20 -0
  60. package/build/bdd-framework/reporter/cucumber/messagesBuilder/AttachmentMapper.js +82 -0
  61. package/build/bdd-framework/reporter/cucumber/messagesBuilder/Builder.js +197 -0
  62. package/build/bdd-framework/reporter/cucumber/messagesBuilder/GherkinDocument.js +43 -0
  63. package/build/bdd-framework/reporter/cucumber/messagesBuilder/GherkinDocumentClone.js +52 -0
  64. package/build/bdd-framework/reporter/cucumber/messagesBuilder/GherkinDocuments.js +105 -0
  65. package/build/bdd-framework/reporter/cucumber/messagesBuilder/Hook.js +70 -0
  66. package/build/bdd-framework/reporter/cucumber/messagesBuilder/Meta.js +44 -0
  67. package/build/bdd-framework/reporter/cucumber/messagesBuilder/Pickles.js +27 -0
  68. package/build/bdd-framework/reporter/cucumber/messagesBuilder/Projects.js +38 -0
  69. package/build/bdd-framework/reporter/cucumber/messagesBuilder/TestCase.js +128 -0
  70. package/build/bdd-framework/reporter/cucumber/messagesBuilder/TestCaseRun.js +154 -0
  71. package/build/bdd-framework/reporter/cucumber/messagesBuilder/TestCaseRunHooks.js +123 -0
  72. package/build/bdd-framework/reporter/cucumber/messagesBuilder/TestStepAttachments.js +66 -0
  73. package/build/bdd-framework/reporter/cucumber/messagesBuilder/TestStepRun.js +113 -0
  74. package/build/bdd-framework/reporter/cucumber/messagesBuilder/index.js +30 -0
  75. package/build/bdd-framework/reporter/cucumber/messagesBuilder/pwStepUtils.js +70 -0
  76. package/build/bdd-framework/reporter/cucumber/messagesBuilder/timing.js +35 -0
  77. package/build/bdd-framework/reporter/cucumber/messagesBuilder/types.js +5 -0
  78. package/build/bdd-framework/run/StepInvoker.js +69 -0
  79. package/build/bdd-framework/run/bddData/index.js +59 -0
  80. package/build/bdd-framework/run/bddData/types.js +5 -0
  81. package/build/bdd-framework/run/bddFixtures.js +192 -0
  82. package/build/bdd-framework/run/bddWorld.js +79 -0
  83. package/build/bdd-framework/run/bddWorldInternal.js +11 -0
  84. package/build/bdd-framework/snippets/index.js +132 -0
  85. package/build/bdd-framework/snippets/snippetSyntax.js +43 -0
  86. package/build/bdd-framework/snippets/snippetSyntaxDecorators.js +26 -0
  87. package/build/bdd-framework/snippets/snippetSyntaxTs.js +18 -0
  88. package/build/bdd-framework/stepDefinitions/createBdd.js +66 -0
  89. package/build/bdd-framework/stepDefinitions/decorators/class.js +68 -0
  90. package/build/bdd-framework/stepDefinitions/decorators/steps.js +99 -0
  91. package/build/bdd-framework/stepDefinitions/defineStep.js +62 -0
  92. package/build/bdd-framework/stepDefinitions/stepConfig.js +24 -0
  93. package/build/bdd-framework/steps/createBdd.js +78 -0
  94. package/build/bdd-framework/steps/decorators/class.js +68 -0
  95. package/build/bdd-framework/steps/decorators/steps.js +98 -0
  96. package/build/bdd-framework/steps/defineStep.js +62 -0
  97. package/build/bdd-framework/steps/stepConfig.js +24 -0
  98. package/build/bdd-framework/utils/AutofillMap.js +20 -0
  99. package/build/bdd-framework/utils/exit.js +62 -0
  100. package/build/bdd-framework/utils/index.js +93 -0
  101. package/build/bdd-framework/utils/jsStringWrap.js +44 -0
  102. package/build/bdd-framework/utils/logger.js +30 -0
  103. package/build/bdd-framework/utils/stripAnsiEscapes.js +20 -0
  104. package/build/core/playwright/clear-caches.js +0 -7
  105. package/build/core/playwright/custom-commands.js +1 -1
  106. package/build/core/playwright/helpers/auth/loginSteps.js +1 -4
  107. package/build/core/playwright/helpers/configFileNameProvider.js +1 -1
  108. package/build/core/playwright/helpers/fileMutex.js +1 -0
  109. package/build/core/playwright/index.js +23 -10
  110. package/build/core/playwright/runner/SpawnRunner.js +2 -2
  111. package/build/core/playwright/setup/config-creator.js +8 -15
  112. package/build/core/playwright/setup/config-utils.js +44 -8
  113. package/build/core/playwright/tagProcessor.js +7 -5
  114. package/build/core/playwright/test-runner.js +6 -2
  115. package/build/core/playwright/types.js +2 -1
  116. package/build/decorators.d.ts +1 -1
  117. package/build/decorators.js +1 -1
  118. package/build/index.js +0 -6
  119. package/build/setup-folder-structure/samples/auth-setup-sample.js +68 -10
  120. package/build/setup-folder-structure/samples/authUsers-sample.json +9 -0
  121. package/build/setup-folder-structure/samples/env-config-sample.json +21 -0
  122. package/build/setup-folder-structure/samples/uat-config-sample.js +1 -3
  123. package/build/setup-folder-structure/setupProject.js +5 -22
  124. package/build/test/core/playwright/__tests__/tagProcessor.test.js +19 -18
  125. package/build/test/core/playwright/helpers/__tests__/configFileNameProvider.test.js +1 -1
  126. package/build/test/core/playwright/helpers/__tests__/fileMutex.test.js +2 -19
  127. package/build/utils/fileUtils.js +16 -0
  128. package/package.json +8 -8
  129. package/playwright.config.js +48 -0
  130. package/zohodesk-testinglibrary-3.1.5.tgz +0 -0
  131. package/build/core/playwright/fixtures.js +0 -24
  132. package/build/setup-folder-structure/samples/accountLogin-sample.js +0 -19
  133. package/build/setup-folder-structure/samples/actors-index.js +0 -2
  134. package/build/setup-folder-structure/samples/editions-index.js +0 -3
  135. package/build/setup-folder-structure/samples/free-sample.json +0 -25
  136. package/build/setup-folder-structure/samples/settings.json +0 -7
  137. package/build/setup-folder-structure/samples/testSetup-sample.js +0 -14
  138. package/build/test/core/playwright/buildInFixtures/__tests__/executionContext.test.js +0 -27
  139. package/npm-shrinkwrap.json +0 -10940
@@ -1,24 +1,37 @@
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
- exports.createBdd = void 0;
7
- Object.defineProperty(exports, "expect", {
7
+ Object.defineProperty(exports, "createBdd", {
8
8
  enumerable: true,
9
9
  get: function () {
10
- return _test.expect;
10
+ return _bddFramework.createBdd;
11
11
  }
12
12
  });
13
- Object.defineProperty(exports, "test", {
13
+ Object.defineProperty(exports, "expect", {
14
14
  enumerable: true,
15
15
  get: function () {
16
- return _playwrightBdd.test;
16
+ return _test.expect;
17
17
  }
18
18
  });
19
- var _playwrightBdd = require("playwright-bdd");
19
+ exports.test = void 0;
20
+ var _bddFramework = require("../../bdd-framework");
20
21
  var _test = require("@playwright/test");
21
- let createBdd = function () {
22
- return (0, _playwrightBdd.createBdd)(_playwrightBdd.test);
23
- };
24
- exports.createBdd = createBdd;
22
+ var _readConfigFile = require("./readConfigFile");
23
+ var _builtInFixtures = _interopRequireDefault(require("./builtInFixtures"));
24
+ var _getUserFixtures = _interopRequireDefault(require("./helpers/getUserFixtures"));
25
+ const {
26
+ bddMode
27
+ } = (0, _readConfigFile.generateConfigFromFile)();
28
+ let base = bddMode ? _bddFramework.test : _test.test;
29
+ const buildInFixtures = (0, _builtInFixtures.default)(bddMode);
30
+ const buildInFixturesTest = base.extend({
31
+ ...buildInFixtures
32
+ });
33
+ const userFixtures = (0, _getUserFixtures.default)();
34
+ const userFixturesTest = base.extend({
35
+ ...userFixtures
36
+ });
37
+ const test = exports.test = (0, _test.mergeTests)(buildInFixturesTest, userFixturesTest);
@@ -33,9 +33,9 @@ class SpawnRunner extends _Runner.default {
33
33
  const {
34
34
  tagArgs
35
35
  } = this.runnerObj;
36
- const configPath = (0, _readConfigFile.isUserConfigFileAvailable)() ? _path.default.resolve(__dirname, '../', 'setup', 'config-creator.js') : _path.default.resolve(__dirname, '../', '../', '../', '../', 'playwrightConfig.js');
36
+ const configPath = (0, _readConfigFile.isUserConfigFileAvailable)() ? _path.default.resolve(__dirname, '../', 'setup', 'config-creator.js') : _path.default.resolve('../', '../', '../', '../', 'playwrightConfig.js');
37
37
  const beforeCommand = 'node';
38
- const bddGenPath = _path.default.resolve((0, _rootPath.getExecutableBinaryPath)('bddgen'));
38
+ const bddGenPath = _path.default.resolve(__dirname, '../', '../', '../', 'bdd-framework', 'cli', 'index.js');
39
39
  const beforeArgs = [bddGenPath, '-c', require.resolve(configPath)];
40
40
  if (tagArgs) {
41
41
  beforeArgs.push('--tags');
@@ -25,8 +25,7 @@ const {
25
25
  featureFilesFolder,
26
26
  stepDefinitionsFolder,
27
27
  testIdAttribute,
28
- globalTimeout,
29
- customReporter
28
+ globalTimeout
30
29
  } = uatConfig;
31
30
  const projects = (0, _configUtils.getProjects)({
32
31
  browsers,
@@ -40,21 +39,12 @@ const testDir = (0, _configUtils.getTestDir)(bddMode, process.cwd(), {
40
39
  featureFilesFolder,
41
40
  stepDefinitionsFolder
42
41
  });
43
- const use = {
42
+ const testOptions = (0, _configUtils.getTestUseOptions)({
44
43
  trace,
45
44
  video,
46
45
  viewport,
47
46
  testIdAttribute
48
- };
49
- let reporter = [['html', {
50
- outputFolder: reportPath,
51
- open: openReportOn
52
- }], ['list'], ['json', {
53
- outputFile: _path.default.join(process.cwd(), 'uat', 'test-results', 'test-results.json')
54
- }], ['./custom-reporter.js']];
55
- if (customReporter) {
56
- reporter = [customReporter, ...reporter];
57
- }
47
+ });
58
48
 
59
49
  /**
60
50
  * Playwright configuration object
@@ -67,12 +57,15 @@ function getPlaywrightConfig() {
67
57
  globalTimeout: globalTimeout || 3600000,
68
58
  outputDir: _path.default.join(process.cwd(), 'uat', 'test-results'),
69
59
  fullyParallel: true,
70
- reporter,
60
+ reporter: [['html', {
61
+ outputFolder: reportPath,
62
+ open: openReportOn
63
+ }], ['list'], ['./custom-reporter.js']],
71
64
  timeout: testTimeout,
72
65
  expect: {
73
66
  timeout: expectTimeout
74
67
  },
75
- use,
68
+ use: testOptions,
76
69
  projects: isAuthMode ? [{
77
70
  name: 'setup',
78
71
  testMatch: /.*\.setup\.js/,
@@ -5,14 +5,17 @@ Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
7
  exports.getBrowsersList = getBrowsersList;
8
+ exports.getModulePathForFeatureFiles = getModulePathForFeatureFiles;
8
9
  exports.getProjects = getProjects;
9
10
  exports.getTestDir = getTestDir;
11
+ exports.getTestUseOptions = getTestUseOptions;
10
12
  var _test = require("@playwright/test");
11
13
  var _path = _interopRequireDefault(require("path"));
12
14
  var _readConfigFile = require("../readConfigFile");
13
- var _playwrightBdd = require("playwright-bdd");
15
+ var _bddFramework = require("../../../bdd-framework");
14
16
  var _logger = require("../../../utils/logger");
15
17
  var _browserTypes = require("../constants/browserTypes");
18
+ var _configFileNameProvider = require("../helpers/configFileNameProvider");
16
19
  var _fileUtils = require("../../../utils/fileUtils");
17
20
  /**
18
21
  ** Playwright project configuration
@@ -140,21 +143,54 @@ function getPathsForFeatureFiles(cwd) {
140
143
  _logger.Logger.log(_logger.Logger.INFO_TYPE, `Unable to read test summary from the ${reportPath}. Verify If File Exists in the path`);
141
144
  _logger.Logger.log(_logger.Logger.INFO_TYPE, 'Going to run all test cases');
142
145
  }
146
+ } else if (process.env.modules !== 'undefined' && process.env.modules.length > 0) {
147
+ let modules = process.env.modules;
148
+ let moduleList = modules.split(',');
149
+ return getModulePathForFeatureFiles(moduleList);
143
150
  }
144
151
  return [_path.default.join(cwd, 'uat', '**', '*.feature')];
145
152
  }
153
+ function getModulePathForFeatureFiles(moduleList) {
154
+ let validModuleList = [];
155
+ moduleList.forEach(moduleName => {
156
+ let modulePath = _path.default.join(process.cwd(), 'uat', 'modules', '**', `${moduleName}`);
157
+ if ((0, _fileUtils.checkIfFolderExistsWithPattern)(modulePath)) {
158
+ validModuleList.push(_path.default.join(modulePath, '**', '*.feature'));
159
+ } else {
160
+ _logger.Logger.log(_logger.Logger.FAILURE_TYPE, `Module ${moduleName} does not exist, Please check the module name`);
161
+ validModuleList = [];
162
+ return validModuleList;
163
+ }
164
+ });
165
+ return validModuleList;
166
+ }
146
167
  function getTestDir(bddMode, cwd, {
147
168
  stepDefinitionsFolder
148
169
  }) {
149
- return bddMode ? (0, _playwrightBdd.defineBddConfig)({
150
- features: getPathsForFeatureFiles(cwd),
151
- steps: [_path.default.join(cwd, 'uat', '**', stepDefinitionsFolder, '*.spec.js'), require.resolve('../fixtures.js')],
152
- importTestFrom: require.resolve('../fixtures.js'),
170
+ return bddMode ? (0, _bddFramework.defineBddConfig)({
171
+ paths: getPathsForFeatureFiles(cwd),
172
+ import: [_path.default.join(cwd, 'uat', '**', stepDefinitionsFolder, '*.spec.js')],
153
173
  featuresRoot: _path.default.join(cwd, 'uat'),
154
174
  outputDir: _path.default.join(cwd, 'uat', '.features-gen'),
155
- disableWarnings: {
156
- importTestFrom: true
157
- },
158
175
  publish: true
159
176
  }) : _path.default.join(cwd, 'uat');
177
+ }
178
+ function getTestUseOptions({
179
+ viewport,
180
+ trace,
181
+ video,
182
+ testIdAttribute
183
+ }) {
184
+ let defaultTestuseOptions = {
185
+ viewport,
186
+ testIdAttribute,
187
+ trace: trace ? 'on' : 'off',
188
+ video: video ? {
189
+ mode: 'on',
190
+ size: {
191
+ ...viewport
192
+ }
193
+ } : 'off'
194
+ };
195
+ return defaultTestuseOptions;
160
196
  }
@@ -10,12 +10,14 @@ class TagProcessor {
10
10
  _classPrivateMethodInitSpec(this, _TagProcessor_brand);
11
11
  this.editionOrder = editionOrder;
12
12
  }
13
- processTags(userArgs) {
14
- const tagArgs = userArgs['tags'] || '';
15
- const edition = userArgs['edition'] || null;
16
- if (!edition) return tagArgs;
13
+ processTags(config) {
14
+ const {
15
+ tags,
16
+ edition
17
+ } = config.getAll();
18
+ if (!edition) return tags;
17
19
  const editionsArray = edition.split(',');
18
- const editionTags = editionsArray.length === 1 ? _assertClassBrand(_TagProcessor_brand, this, _processSingleEdition).call(this, editionsArray[0], tagArgs) : _assertClassBrand(_TagProcessor_brand, this, _processMultipleEditions).call(this, editionsArray, tagArgs);
20
+ const editionTags = editionsArray.length === 1 ? _assertClassBrand(_TagProcessor_brand, this, _processSingleEdition).call(this, editionsArray[0], tags) : _assertClassBrand(_TagProcessor_brand, this, _processMultipleEditions).call(this, editionsArray, tags);
19
21
  return editionTags;
20
22
  }
21
23
  }
@@ -24,7 +24,7 @@ var _RunnerHelper = _interopRequireDefault(require("./runner/RunnerHelper"));
24
24
  var _Runner = _interopRequireDefault(require("./runner/Runner"));
25
25
  function runPreprocessing(tagArgs, configPath) {
26
26
  const beforeCommand = 'node';
27
- const bddGenPath = _path.default.resolve((0, _rootPath.getExecutableBinaryPath)('bddgen'));
27
+ const bddGenPath = _path.default.resolve(__dirname, '../', '../', 'bdd-framework', 'cli', 'index.js');
28
28
  const beforeArgs = [bddGenPath, '-c', configPath];
29
29
  if (tagArgs) {
30
30
  beforeArgs.push('--tags');
@@ -92,6 +92,10 @@ function main() {
92
92
 
93
93
  // overriding the user config's from CLI
94
94
  uatConfig.addAll(userArgConfig);
95
+ const modules = uatConfig.get('modules');
96
+
97
+ //We need to change this process.env variable to pass the module name in future.
98
+ process.env.modules = modules;
95
99
  const {
96
100
  isAuthMode,
97
101
  editionOrder,
@@ -104,7 +108,7 @@ function main() {
104
108
  //This is only used for pass the user arguments to need places in legacy code. We need to rewamp that also.
105
109
  const userArgsObject = userArgConfig.getAll();
106
110
  const tagProcessor = new _tagProcessor.default(editionOrder);
107
- const tagArgs = tagProcessor.processTags(userArgsObject);
111
+ const tagArgs = tagProcessor.processTags(uatConfig);
108
112
  const runnerObj = new _Runner.default();
109
113
  runnerObj.setTagArgs(tagArgs);
110
114
  runnerObj.setUserArgs(userArgsObject);
@@ -39,5 +39,6 @@
39
39
  * @property {string} testIdAttribute: Change the default data-testid attribute. configure what attribute to search while calling getByTestId
40
40
  * @property {Array} editionOrder: Order in the form of larger editions in the back. Edition with the most privelages should be last
41
41
  * @property {testSetupConfig} testSetup: Specify page and context functions that will be called while intilaizing fixtures.
42
- */
42
+ * @property {string} modules: Modules name to be used for running the specific module test cases.
43
+ */
43
44
  "use strict";
@@ -1 +1 @@
1
- export * from 'playwright-bdd/decorators';
1
+ export * from './bdd-framework/decorators';
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- var _decorators = require("playwright-bdd/decorators");
6
+ var _decorators = require("./bdd-framework/decorators");
7
7
  Object.keys(_decorators).forEach(function (key) {
8
8
  if (key === "default" || key === "__esModule") return;
9
9
  if (key in exports && exports[key] === _decorators[key]) return;
package/build/index.js CHANGED
@@ -70,12 +70,6 @@ Object.defineProperty(exports, "performLoginSteps", {
70
70
  return _index.performLoginSteps;
71
71
  }
72
72
  });
73
- Object.defineProperty(exports, "setup", {
74
- enumerable: true,
75
- get: function () {
76
- return _index.setup;
77
- }
78
- });
79
73
  Object.defineProperty(exports, "test", {
80
74
  enumerable: true,
81
75
  get: function () {
@@ -1,15 +1,73 @@
1
1
  /* eslint-disable no-console */
2
2
  import { test as setup, expect } from '@zohodesk/testinglibrary';
3
- import {
4
- performLoginSteps,
5
- getDefaultActor
6
- } from '@zohodesk/testinglibrary/helpers';
3
+ import path from 'path';
4
+ import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'fs';
5
+ import { getAuthFileDirectory } from '../../core/playwright';
6
+ import { Logger } from '../../utils/logger';
7
7
 
8
- import { loginSteps , validateLogin } from './testSetup';
8
+ const userdata = require('./authUsers.json');
9
9
 
10
- const user = getDefaultActor();
10
+ const authContent = { cookies: [] };
11
11
 
12
- setup(`${user.edition} - Authentication`, async ({ page }) => {
13
- //Implement performLoginSteps here
14
- await performLoginSteps({page, ...user},validateLogin ,loginSteps);
15
- });
12
+ const LOGIN_ERR_MESSAGE = 'Need go be logged in';
13
+ // const AUTH_ERR_MESSAGE = `Founded Path - ${path.resolve(process.cwd(),'uat','playwright','.auth')} \n Find if file is Properly Created. Cookies Cannot Be Read .. `
14
+
15
+ function convertCookiesToParse(cookies, authFilePath) {
16
+ try {
17
+ return JSON.parse(cookies);
18
+ } catch (err) {
19
+ Logger.error(err);
20
+ throw new Error(
21
+ ` Error while parsing cookies ${err} \n${path.resolve(
22
+ process.cwd(),
23
+ authFilePath
24
+ )} File is Empty`
25
+ );
26
+ // process.exit()
27
+ }
28
+ }
29
+ const authDirectory = getAuthFileDirectory(); //path.resolve(process.cwd(), 'uat', 'playwright', '.auth');
30
+ if (!existsSync(authDirectory)) {
31
+ console.log('Creating auth directory for the first time setup...');
32
+ mkdirSync(authDirectory, { recursive: true });
33
+ }
34
+
35
+ userdata.forEach(data => {
36
+ const authFile = path.resolve(path.join(authDirectory, `${data.filename}`));
37
+ if (!existsSync(authFile)) {
38
+ console.log('creating auth file..');
39
+ writeFileSync(authFile, JSON.stringify(authContent, null, 2));
40
+ }
41
+ setup(data.description, async ({ page }) => {
42
+ try {
43
+ const cookies = readFileSync(authFile);
44
+ const parsedCookies = convertCookiesToParse(cookies, authFile);
45
+ await page
46
+ .context()
47
+ .addCookies(
48
+ parsedCookies.cookies === undefined ? [] : parsedCookies.cookies
49
+ );
50
+ await page.goto(page.getBaseUrl());
51
+ await page.waitForLoadState();
52
+ if (await page.url().includes(process.env.domain)) {
53
+ await page.waitForSelector(data.locator);
54
+ } else {
55
+ throw new Error(LOGIN_ERR_MESSAGE);
56
+ }
57
+ } catch (err) {
58
+ if (err.message === LOGIN_ERR_MESSAGE) {
59
+ await expect(page.locator('.load-bg')).toBeHidden();
60
+ await page.locator('#login_id').type(data.useremail);
61
+ await page.locator('#nextbtn').click();
62
+ await page.locator('#password').type(data.password);
63
+ await page.locator('#nextbtn').click();
64
+
65
+ await page.waitForLoadState('networkidle');
66
+
67
+ await page.waitForSelector(data.locator);
68
+
69
+ await page.context().storageState({ path: authFile });
70
+ }
71
+ }
72
+ });
73
+ });
@@ -0,0 +1,9 @@
1
+ [
2
+ {
3
+ "useremail": "/ user name /",
4
+ "password": "/ password /",
5
+ "description": "/ description/",
6
+ "filename": "user.json",
7
+ "locator": "/ selector to identify page has been loaded completely /"
8
+ }
9
+ ]
@@ -0,0 +1,21 @@
1
+ {
2
+ "dev": {
3
+ "domain": "https://desk.localzoho.com/agent",
4
+ "orgName": "org-name",
5
+ "deptName": "dept-name",
6
+ "moduleName": "module-name",
7
+ "devURL": "Provide your devURL here"
8
+ },
9
+ "prod": {
10
+ "domain": "https://desk.localzoho.com/agent",
11
+ "orgName": "org-name",
12
+ "deptName": "dept-name",
13
+ "moduleName": "module-name"
14
+ },
15
+ "k8test": {
16
+ "domain": "https://desk.localzoho.com/agent",
17
+ "orgName": "org-name",
18
+ "deptName": "dept-name",
19
+ "moduleName": "module-name"
20
+ }
21
+ }
@@ -1,4 +1,3 @@
1
- const testSetup = require('../../fixtures/testSetup');
2
1
  /**
3
2
  * @typedef {Object|null} viewportConfig
4
3
  * @property {number} width - width of the viewport
@@ -41,6 +40,5 @@ module.exports = {
41
40
  bddMode: true,
42
41
  featureFilesFolder: 'feature-files',
43
42
  stepDefinitionsFolder: 'steps',
44
- viewport: { width: 1280, height: 720 },
45
- testSetup
43
+ viewport: { width: 1280, height: 720 }
46
44
  }
@@ -10,9 +10,8 @@ var _path = _interopRequireDefault(require("path"));
10
10
  var _logger = require("../utils/logger");
11
11
  function getScriptsToBeAdded() {
12
12
  return {
13
- "uat": "ZDTestingFramework test --mode=dev --headed",
14
- "uat-debug": "ZDTestingFramework test --mode=dev --debug",
15
- "uat-validate": "ZDTestingFramework validate",
13
+ "uat": "ZDTestingFramework test --mode=prod --headed",
14
+ "uat-debug": "ZDTestingFramework test --mode=prod --debug",
16
15
  "uat-report": "ZDTestingFramework report --port=9009",
17
16
  "codegen": "ZDTestingFramework codegen deskclientapp.localzoho.com/agent"
18
17
  };
@@ -72,11 +71,8 @@ function createAuthenticationFile() {
72
71
  });
73
72
  }
74
73
  (0, _fs.writeFileSync)(_path.default.resolve(process.cwd(), 'uat', 'fixtures', 'auth.setup.js'), getSetupFileAsString('auth-setup-sample.js'), null, 2);
74
+ (0, _fs.writeFileSync)(_path.default.resolve(process.cwd(), 'uat', 'fixtures', 'authUsers.json'), getSetupFileAsString('authUsers-sample.json'), null, 2);
75
75
  _logger.Logger.log(_logger.Logger.INFO_TYPE, 'Creating Authentication File ....');
76
- (0, _fs.writeFileSync)(_path.default.resolve(process.cwd(), 'uat', 'fixtures', 'accountLogin.js'), getSetupFileAsString('accountLogin-sample.js'), null, 2);
77
- _logger.Logger.log(_logger.Logger.INFO_TYPE, 'Creating login script File ....');
78
- (0, _fs.writeFileSync)(_path.default.resolve(process.cwd(), 'uat', 'fixtures', 'testSetup.js'), getSetupFileAsString('testSetup-sample.js'), null, 2);
79
- _logger.Logger.log(_logger.Logger.INFO_TYPE, 'Creating testSetup File ....');
80
76
  } catch (err) {
81
77
  _logger.Logger.error(err);
82
78
  _logger.Logger.log(_logger.Logger.FAILURE_TYPE, 'Something went wrong ! Folder not Created. Please re-initialize npm init-uat');
@@ -88,21 +84,8 @@ function createAuthenticationFile() {
88
84
  function createConfigJson() {
89
85
  const uatFolder = _path.default.resolve(process.cwd(), 'uat');
90
86
  if ((0, _fs.existsSync)(uatFolder)) {
91
- _logger.Logger.log(_logger.Logger.INFO_TYPE, 'Creating settings.json file inside UAT Folder');
92
- if (!(0, _fs.existsSync)(_path.default.resolve(uatFolder, 'conf', 'default'))) {
93
- (0, _fs.mkdirSync)(_path.default.resolve(uatFolder, 'conf', 'default'), {
94
- recursive: true
95
- });
96
- }
97
- (0, _fs.writeFileSync)(_path.default.resolve(uatFolder, 'conf', 'default', './settings.json'), getSetupFileAsString('settings.json'), null, 2);
98
- if (!(0, _fs.existsSync)(_path.default.resolve(uatFolder, 'conf', 'default', 'actors', 'editions'))) {
99
- (0, _fs.mkdirSync)(_path.default.resolve(uatFolder, 'conf', 'default', 'actors', 'editions'), {
100
- recursive: true
101
- });
102
- }
103
- (0, _fs.writeFileSync)(_path.default.resolve(uatFolder, 'conf', 'default', 'actors', 'editions', 'free.json'), getSetupFileAsString('free-sample.json'), null, 2);
104
- (0, _fs.writeFileSync)(_path.default.resolve(uatFolder, 'conf', 'default', 'actors', 'editions', 'index.js'), getSetupFileAsString('editions-index.js'), null, 2);
105
- (0, _fs.writeFileSync)(_path.default.resolve(uatFolder, 'conf', 'default', 'actors', 'index.js'), getSetupFileAsString('actors-index.js'), null, 2);
87
+ _logger.Logger.log(_logger.Logger.INFO_TYPE, 'Creating env-config file inside UAT Folder');
88
+ (0, _fs.writeFileSync)(_path.default.resolve(uatFolder, './env-config.json'), getSetupFileAsString('env-config-sample.json'), null, 2);
106
89
  } else {
107
90
  _logger.Logger.log(_logger.Logger.INFO_TYPE, 'Something went wrong. Please re-initialize the @zohodesk/testinglibrary');
108
91
  }
@@ -2,6 +2,7 @@
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
4
  var _tagProcessor = _interopRequireDefault(require("../../../../../src/core/playwright/tagProcessor"));
5
+ var _Configuration = _interopRequireDefault(require("../../../../../src/core/playwright/configuration/Configuration.js"));
5
6
  var _logger = require("../../../../utils/logger");
6
7
  jest.mock('../../../../utils/logger');
7
8
  describe('TagProcessor', () => {
@@ -11,83 +12,83 @@ describe('TagProcessor', () => {
11
12
  });
12
13
  test('should return tagArgs if no edition is provided', () => {
13
14
  const tagProcessor = new _tagProcessor.default(editionOrder);
14
- const userArgs = {
15
+ const userArgs = new _Configuration.default({
15
16
  tags: 'tag1',
16
17
  edition: null
17
- };
18
+ });
18
19
  const result = tagProcessor.processTags(userArgs);
19
20
  expect(result).toBe('tag1');
20
21
  });
21
22
  test('should handle a single edition with <= operator', () => {
22
23
  const tagProcessor = new _tagProcessor.default(editionOrder);
23
- const userArgs = {
24
+ const userArgs = new _Configuration.default({
24
25
  tags: 'tag1',
25
26
  edition: '<=edition2'
26
- };
27
+ });
27
28
  const result = tagProcessor.processTags(userArgs);
28
29
  expect(result).toBe('tag1 and not (@edition_edition3 or @edition_edition4)');
29
30
  });
30
31
  test('should handle a single edition with >= operator', () => {
31
32
  const tagProcessor = new _tagProcessor.default(editionOrder);
32
- const userArgs = {
33
+ const userArgs = new _Configuration.default({
33
34
  tags: 'tag1',
34
35
  edition: '>=edition2'
35
- };
36
+ });
36
37
  const result = tagProcessor.processTags(userArgs);
37
38
  expect(result).toBe('tag1 and not (@edition_edition1)');
38
39
  });
39
40
  test('should handle a single edition with < operator', () => {
40
41
  const tagProcessor = new _tagProcessor.default(editionOrder);
41
- const userArgs = {
42
+ const userArgs = new _Configuration.default({
42
43
  tags: 'tag1',
43
44
  edition: '<edition3'
44
- };
45
+ });
45
46
  const result = tagProcessor.processTags(userArgs);
46
47
  expect(result).toBe('tag1 and not (@edition_edition3 or @edition_edition4)');
47
48
  });
48
49
  test('should handle a single edition with > operator', () => {
49
50
  const tagProcessor = new _tagProcessor.default(editionOrder);
50
- const userArgs = {
51
+ const userArgs = new _Configuration.default({
51
52
  tags: 'tag1',
52
53
  edition: '>edition1'
53
- };
54
+ });
54
55
  const result = tagProcessor.processTags(userArgs);
55
56
  expect(result).toBe('tag1 and not (@edition_edition1)');
56
57
  });
57
58
  test('should handle a single edition with no operator', () => {
58
59
  const tagProcessor = new _tagProcessor.default(editionOrder);
59
- const userArgs = {
60
+ const userArgs = new _Configuration.default({
60
61
  tags: 'tag1',
61
62
  edition: 'edition2'
62
- };
63
+ });
63
64
  const result = tagProcessor.processTags(userArgs);
64
65
  expect(result).toBe('tag1 and not (@edition_edition1 or @edition_edition3 or @edition_edition4)');
65
66
  });
66
67
  test('should log a message if edition is not found', () => {
67
68
  const tagProcessor = new _tagProcessor.default(editionOrder);
68
- const userArgs = {
69
+ const userArgs = new _Configuration.default({
69
70
  tags: 'tag1',
70
71
  edition: 'nonexistentEdition'
71
- };
72
+ });
72
73
  const result = tagProcessor.processTags(userArgs);
73
74
  expect(result).toBe('tag1');
74
75
  expect(_logger.Logger.log).toHaveBeenCalledWith(_logger.Logger.INFO_TYPE, expect.stringContaining('No matching editions for nonexistentEdition found.'));
75
76
  });
76
77
  test('should handle multiple editions', () => {
77
78
  const tagProcessor = new _tagProcessor.default(editionOrder);
78
- const userArgs = {
79
+ const userArgs = new _Configuration.default({
79
80
  tags: 'tag1',
80
81
  edition: 'edition1,edition3'
81
- };
82
+ });
82
83
  const result = tagProcessor.processTags(userArgs);
83
84
  expect(result).toBe('tag1 and not (@edition_edition2 or @edition_edition4)');
84
85
  });
85
86
  test('should build tags correctly when tags are empty', () => {
86
87
  const tagProcessor = new _tagProcessor.default(editionOrder);
87
- const userArgs = {
88
+ const userArgs = new _Configuration.default({
88
89
  tags: '',
89
90
  edition: 'edition1'
90
- };
91
+ });
91
92
  const result = tagProcessor.processTags(userArgs);
92
93
  expect(result).toBe('not (@edition_edition2 or @edition_edition3 or @edition_edition4)');
93
94
  });
@@ -24,7 +24,7 @@ describe('getUATFileName', () => {
24
24
  });
25
25
  test('return the default config files for pipeline matched files not exists', () => {
26
26
  const mode = 'ci';
27
- const defaultPath = `${mockCwd}/uat/conf/default/uat.config.js`;
27
+ const defaultPath = `${mockCwd}/uat.config.js`;
28
28
  _fs.existsSync.mockReturnValue(false);
29
29
  _path.default.resolve.mockImplementation((...args) => args.join('/'));
30
30
  const result = (0, _configFileNameProvider.getUATFileName)(mode);
@@ -8,8 +8,6 @@ jest.mock('fs');
8
8
  describe('FileMutex', () => {
9
9
  const directory = '/tmp/locks';
10
10
  const lockFileName = 'test-lock';
11
- const email = 'test@example.com';
12
- const authFile = '/tmp/authFile';
13
11
  const fileDeletionTimeoutConfig = {
14
12
  timeout: 1000
15
13
  };
@@ -17,27 +15,14 @@ describe('FileMutex', () => {
17
15
  let fileMutex;
18
16
  beforeEach(() => {
19
17
  jest.clearAllMocks();
20
- fileMutex = new _fileMutex.default(directory, lockFileName, email, authFile, fileDeletionTimeoutConfig);
18
+ fileMutex = new _fileMutex.default(directory, lockFileName, fileDeletionTimeoutConfig);
21
19
  });
22
20
  describe('acquire', () => {
23
- it('should create directory if it does not exist', async () => {
24
- _fs.existsSync.mockReturnValue(false);
25
- await fileMutex.createDirectoryIfNotExist();
26
- expect(_fs.mkdirSync).toHaveBeenCalledWith(directory, {
27
- recursive: true
28
- });
29
- });
30
21
  it('should create the lock file if it does not exist', async () => {
31
- _fs.existsSync.mockImplementation(filePath => filePath === authFile ? false : false);
32
22
  _fs.writeFileSync.mockImplementation(() => {});
33
23
  await fileMutex.acquire();
34
24
  expect(_fs.writeFileSync).toHaveBeenCalledWith(fileMutex.lockFilePath, 'locked');
35
25
  });
36
- it('should resolve immediately if auth file exists', async () => {
37
- _fs.existsSync.mockImplementation(filePath => filePath === authFile);
38
- await fileMutex.acquire();
39
- expect(_fs.existsSync).toHaveBeenCalledWith(authFile);
40
- });
41
26
  it('should wait for lock file deletion if it exists', async () => {
42
27
  _fs.existsSync.mockImplementation(filePath => filePath === fileMutex.lockFilePath);
43
28
  _fs.watch.mockImplementation((dir, callback) => {
@@ -88,9 +73,7 @@ describe('FileMutex', () => {
88
73
  _fs.unlinkSync.mockImplementation(() => {
89
74
  throw new Error(errorMessage);
90
75
  });
91
- console.error = jest.fn();
92
- await fileMutex.release();
93
- expect(console.error).toHaveBeenCalledWith(`Error deleting lock file: ${errorMessage}`);
76
+ await expect(fileMutex.release()).rejects.toThrow(errorMessage);
94
77
  });
95
78
  });
96
79
  });