@zohodesk/testinglibrary 0.4.8-experimental → 2.9.2

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 (163) hide show
  1. package/.gitlab-ci.yml +1 -23
  2. package/README.md +6 -27
  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 +126 -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 +312 -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 +45 -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 +67 -0
  73. package/build/bdd-framework/reporter/cucumber/messagesBuilder/TestStepRun.js +114 -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/builtInFixtures/page.js +0 -7
  105. package/build/core/playwright/constants/fileMutexConfig.js +11 -0
  106. package/build/core/playwright/helpers/auth/checkAuthCookies.js +2 -8
  107. package/build/core/playwright/helpers/auth/loginSteps.js +25 -18
  108. package/build/core/playwright/helpers/checkAuthDirectory.js +17 -0
  109. package/build/core/playwright/helpers/fileMutex.js +58 -0
  110. package/build/core/playwright/index.js +23 -10
  111. package/build/core/playwright/setup/config-creator.js +3 -3
  112. package/build/core/playwright/setup/config-utils.js +25 -8
  113. package/build/core/playwright/test-runner.js +35 -9
  114. package/build/decorators.d.ts +1 -1
  115. package/build/decorators.js +1 -1
  116. package/build/setup-folder-structure/samples/auth-setup-sample.js +66 -14
  117. package/build/setup-folder-structure/samples/authUsers-sample.json +9 -0
  118. package/build/setup-folder-structure/samples/env-config-sample.json +21 -0
  119. package/build/setup-folder-structure/setupProject.js +5 -18
  120. package/build/test/core/playwright/helpers/__tests__/fileMutex.test.js +94 -0
  121. package/nobdd/uat/conf/nobdd/uat.config.js +11 -4
  122. package/nobdd/uat.config.js +8 -3
  123. package/npm-shrinkwrap.json +6475 -0
  124. package/package.json +8 -7
  125. package/build/core/playwright/fixtures.js +0 -24
  126. package/build/core/playwright/runner/Runner.js +0 -22
  127. package/build/core/playwright/runner/RunnerHelper.js +0 -43
  128. package/build/core/playwright/runner/RunnerTypes.js +0 -17
  129. package/build/core/playwright/runner/SpawnRunner.js +0 -110
  130. package/build/setup-folder-structure/samples/actors-index.js +0 -2
  131. package/build/setup-folder-structure/samples/editions-index.js +0 -3
  132. package/build/setup-folder-structure/samples/free-sample.json +0 -25
  133. package/build/setup-folder-structure/samples/settings.json +0 -7
  134. package/build/test/Test.js +0 -11
  135. package/build/test/core/playwright/runner/__tests__/RunnerHelper.test.js +0 -16
  136. package/build/test/core/playwright/runner/__tests__/SpawnRunner.test.js +0 -27
  137. package/nobdd/uat/playwright/.auth/anitha.m+clientat@zohotest.com-cookies.json +0 -276
  138. package/nobdd/uat/playwright/.auth/anitha.m+clientattest@zohotest.com-cookies.json +0 -3
  139. package/nobdd/uat/playwright/.auth/anitha.m+uat@zohotest.com-cookies.json +0 -3
  140. package/nobdd/uat/playwright/.auth/skumaresan@zohotest.com-cookies.json +0 -503
  141. package/nobdd/uat/playwright/.auth/solairaj.m+26jun2023@zohotest.com-cookies.json +0 -173
  142. package/nobdd/uat/playwright/.auth/sridhar.parthasarathy@zohotest.com-cookies.json +0 -520
  143. package/nobdd/uat/playwright-report/data/15676399fddfec429bc2935c407212f42cfa65b2.webm +0 -0
  144. package/nobdd/uat/playwright-report/data/7be7af3de16a483f32cdcb86b3a290f584e21f76.zip +0 -0
  145. package/nobdd/uat/playwright-report/index.html +0 -68
  146. package/nobdd/uat/playwright-report/test-summary.json +0 -17
  147. package/nobdd/uat/playwright-report/trace/assets/codeMirrorModule-BK3t1EEu.js +0 -24
  148. package/nobdd/uat/playwright-report/trace/assets/wsPort-964mA9MZ.js +0 -69
  149. package/nobdd/uat/playwright-report/trace/codeMirrorModule.Hs9-1ZG4.css +0 -1
  150. package/nobdd/uat/playwright-report/trace/codicon.zGuYmc9o.ttf +0 -0
  151. package/nobdd/uat/playwright-report/trace/index.-g_5lMbJ.css +0 -1
  152. package/nobdd/uat/playwright-report/trace/index.cbtHmFgM.js +0 -2
  153. package/nobdd/uat/playwright-report/trace/index.html +0 -26
  154. package/nobdd/uat/playwright-report/trace/playwright-logo.svg +0 -9
  155. package/nobdd/uat/playwright-report/trace/snapshot.html +0 -21
  156. package/nobdd/uat/playwright-report/trace/sw.bundle.js +0 -4
  157. package/nobdd/uat/playwright-report/trace/uiMode.fcU_T5Nf.js +0 -10
  158. package/nobdd/uat/playwright-report/trace/uiMode.html +0 -17
  159. package/nobdd/uat/playwright-report/trace/uiMode.pWy0Re7G.css +0 -1
  160. package/nobdd/uat/playwright-report/trace/wsPort.zR1WIy9-.css +0 -1
  161. package/nobdd/uat/playwright-report/trace/xtermModule.0lwXJFHT.css +0 -32
  162. package/nobdd/uat/test-results/modules-nobdd-steps-ExamplesForTestData.featur-a74c6-required-nobdd-Verify-the-page-is-not-logged-in-chromium/trace.zip +0 -0
  163. package/nobdd/uat/test-results/modules-nobdd-steps-ExamplesForTestData.featur-a74c6-required-nobdd-Verify-the-page-is-not-logged-in-chromium/video.webm +0 -0
package/.gitlab-ci.yml CHANGED
@@ -1,4 +1,4 @@
1
- image: repository.desk.csez.zohocorpin.com/base-image/testing-framework-gitlab-runne-base:v3
1
+ image: repository.desk.csez.zohocorpin.com/base-image/testing-framework-gitlab-runne-base:v2
2
2
 
3
3
  workflow:
4
4
  rules:
@@ -86,27 +86,6 @@ uat-profile:
86
86
  paths:
87
87
  - examples/uat/playwright-report
88
88
 
89
-
90
- uat-unauth:
91
- stage: uat
92
- image: repository.desk.csez.zohocorpin.com/base-image/testing-framework-gitlab-runne-base:v2
93
- script:
94
- - npm install
95
- - npm run build
96
- - cd examples
97
- - npm install $(npm pack ../../testing-framework | tail -1)
98
- - output=$(npm run uatunauth)
99
- - echo "$output"
100
- - if [[ "$output" == *"failed"* ]]; then
101
- - exit 1
102
- - fi
103
-
104
-
105
- artifacts:
106
- when: always
107
- paths:
108
- - examples/uat/playwright-report
109
-
110
89
  uat-nobdd:
111
90
  stage: uat
112
91
  script:
@@ -123,4 +102,3 @@ uat-nobdd:
123
102
  when: always
124
103
  paths:
125
104
  - nobdd/uat/playwright-report
126
-
package/README.md CHANGED
@@ -26,41 +26,20 @@
26
26
  ### Bug fix
27
27
  - Updated the custom-reported to include the errors in tests during the executions. It will help us avoid the stage passed without the actual test execution.
28
28
 
29
-
30
- ## Version History
31
-
32
- ### v0.2.9 - 25-10-2024
29
+ ### v0.2.9 - 24-10-2024
33
30
 
34
31
  #### Feature
35
32
  - Added support for scenario level tag support
36
33
  - Added a new cli optin like uat-validate to validate the feature files using playwright-bdd
37
34
  - Mode based configuration implementations
38
35
  - @only option enabled in dev pipeline
39
- - Latest setup related configuration changed for init option
40
-
41
- ### v0.3.0 - 25-10-2024
42
-
43
- #### Features
44
- - Added support for scenario level tag support
45
- - Updated the configuration for `video` and `trace` to accept Playwright-specific values instead of boolean values.
46
- - Below package versions are updated in this release.
47
- - playwright - 1.48.0,
48
- - playwright-bdd - 7.5.0,
49
- - @playwright/test - 1.48.0,
50
- - @cucumber/cucumber - 11.0.1
51
- - From this version, We adopt the playwright-bdd as library instead of modified source
52
- - Published on 11-11-2024
53
-
54
- #### Deprecations
55
- - **Deprecated**: Passing `video` and `trace` as boolean (`true`/`false`) in project configuration.
56
- - **New Approach**: Use Playwright values for `video` and `trace` options, such as `'on'`, `'retain-on-failure'`, or `'off'`.
57
-
58
- ### v0.3.1 - 13-11-2024
59
-
60
- #### Issue Fix
61
- - Adding bddmode to get the fixtures.
62
36
 
63
37
  ### v0.2.9.1 - 14-11-2024
64
38
 
65
39
  #### Enhancement
66
40
  - Beta feature Actors and edition configurations are unified
41
+
42
+ ### v0.2.9.2 - 22-11-2024
43
+
44
+ #### BugFix
45
+ - Implemented synchronization for the login process. This fix will help avoid login session-related failures in UAT.
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.envCommand = void 0;
8
+ exports.getOwnVersion = getOwnVersion;
9
+ var _commander = require("commander");
10
+ var _options = require("../options");
11
+ var _path = _interopRequireDefault(require("path"));
12
+ var _logger = require("../../utils/logger");
13
+ var _utils = require("../../utils");
14
+ var _loadConfig = require("../../playwright/loadConfig");
15
+ const logger = new _logger.Logger({
16
+ verbose: true
17
+ });
18
+ const envCommand = exports.envCommand = new _commander.Command('env').description('Prints environment info').addOption(_options.configOption).action(opts => {
19
+ logger.log(`Playwright-bdd environment info:\n`);
20
+ logger.log(`platform: ${process.platform}`);
21
+ logger.log(`node: ${process.version}`);
22
+ showPackageVersion('playwright-bdd');
23
+ showPackageVersion('@playwright/test');
24
+ showPackageVersion('@cucumber/cucumber');
25
+ showPlaywrightConfigPath(opts.config);
26
+ });
27
+ function showPackageVersion(packageName) {
28
+ const version = packageName === 'playwright-bdd' ? getOwnVersion() : (0, _utils.getPackageVersion)(packageName);
29
+ logger.log(`${packageName}: v${version}`);
30
+ }
31
+ /**
32
+ * Getting own version by relative path instead of using getPackageVersion(),
33
+ * to aneble using directly from /dist in tests.
34
+ */
35
+ function getOwnVersion() {
36
+ return '6.1.1';
37
+ }
38
+ function showPlaywrightConfigPath(cliConfigPath) {
39
+ const resolvedConfigFile = (0, _loadConfig.resolveConfigFile)(cliConfigPath);
40
+ const relPath = _path.default.relative(process.cwd(), resolvedConfigFile);
41
+ logger.log(`Playwright config file: ${relPath}`);
42
+ }
@@ -0,0 +1,62 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.exportCommand = void 0;
8
+ var _path = _interopRequireDefault(require("path"));
9
+ var _commander = require("commander");
10
+ var _options = require("../options");
11
+ var _loadConfig = require("../../playwright/loadConfig");
12
+ var _logger = require("../../utils/logger");
13
+ var _env = require("../../config/env");
14
+ var _test = require("./test");
15
+ var _gen = require("../../gen");
16
+ const logger = new _logger.Logger({
17
+ verbose: true
18
+ });
19
+ const exportCommand = exports.exportCommand = new _commander.Command('export').description('Prints step definitions').addOption(_options.configOption).option('--unused-steps', 'Output only unused steps').action(async opts => {
20
+ const {
21
+ resolvedConfigFile
22
+ } = await (0, _loadConfig.loadConfig)(opts.config);
23
+ logger.log(`Using config: ${_path.default.relative(process.cwd(), resolvedConfigFile)}`);
24
+ const configs = Object.values((0, _env.getEnvConfigs)());
25
+ (0, _test.assertConfigsCount)(configs);
26
+ if (opts.unusedSteps) {
27
+ await showUnusedStepsForConfigs(configs);
28
+ } else {
29
+ await showStepsForConfigs(configs);
30
+ }
31
+ });
32
+ async function showStepsForConfigs(configs) {
33
+ // here we don't need workers (as in test command) because if some step files
34
+ // are already in node cache, we collected them.
35
+ const steps = new Set();
36
+ const tasks = configs.map(async config => {
37
+ const stepDefinitions = await new _gen.TestFilesGenerator(config).extractSteps();
38
+ stepDefinitions.forEach(s => steps.add(`* ${getStepText(s)}`));
39
+ });
40
+ await Promise.all(tasks);
41
+ logger.log(`List of all steps (${steps.size}):`);
42
+ steps.forEach(stepText => logger.log(stepText));
43
+ }
44
+ async function showUnusedStepsForConfigs(configs) {
45
+ const steps = new Set();
46
+ const tasks = configs.map(async config => {
47
+ const stepDefinitions = await new _gen.TestFilesGenerator(config).extractUnusedSteps();
48
+ stepDefinitions.forEach(s => steps.add(`* ${getStepText(s)}`));
49
+ });
50
+ await Promise.all(tasks);
51
+ logger.log(`List of unused steps (${steps.size}):`);
52
+ steps.forEach(stepText => logger.log(stepText));
53
+ }
54
+ function getStepText({
55
+ pattern,
56
+ keyword
57
+ }) {
58
+ // for Unknown return When as it looks the most suitable
59
+ const keywordText = keyword === 'Unknown' ? 'When' : keyword;
60
+ const patternText = typeof pattern === 'string' ? pattern : pattern.source;
61
+ return `${keywordText} ${patternText}`;
62
+ }
@@ -0,0 +1,64 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.assertConfigsCount = assertConfigsCount;
8
+ exports.testCommand = void 0;
9
+ var _worker_threads = require("worker_threads");
10
+ var _events = require("events");
11
+ var _path = _interopRequireDefault(require("path"));
12
+ var _commander = require("commander");
13
+ var _gen = require("../../gen");
14
+ var _loadConfig = require("../../playwright/loadConfig");
15
+ var _env = require("../../config/env");
16
+ var _config = require("../../config");
17
+ var _options = require("../options");
18
+ var _exit = require("../../utils/exit");
19
+ const GEN_WORKER_PATH = _path.default.resolve(__dirname, '..', 'worker.js');
20
+ const testCommand = exports.testCommand = new _commander.Command('test').description('Generate Playwright test files from Gherkin documents').addOption(_options.configOption).option('--tags <expression>', `Tags expression to filter scenarios for generation`).option('--verbose', `Verbose mode (default: ${Boolean(_config.defaults.verbose)})`).action(async opts => {
21
+ await (0, _loadConfig.loadConfig)(opts.config);
22
+ const configs = readConfigsFromEnv();
23
+ mergeCliOptions(configs, opts);
24
+ await generateFilesForConfigs(configs);
25
+ });
26
+ function readConfigsFromEnv() {
27
+ const configs = Object.values((0, _env.getEnvConfigs)());
28
+ assertConfigsCount(configs);
29
+ return configs;
30
+ }
31
+ function mergeCliOptions(configs, opts) {
32
+ configs.forEach(config => {
33
+ if ('tags' in opts) {
34
+ config.tags = opts.tags;
35
+ }
36
+ if ('verbose' in opts) {
37
+ config.verbose = Boolean(opts.verbose);
38
+ }
39
+ });
40
+ }
41
+ function assertConfigsCount(configs) {
42
+ if (configs.length === 0) {
43
+ (0, _exit.exit)(`No BDD configs found. Did you use defineBddConfig() in playwright.config.ts?`);
44
+ }
45
+ }
46
+ async function generateFilesForConfigs(configs) {
47
+ // run first config in main thread and other in workers (to have fresh require cache)
48
+ // See: https://github.com/vitalets/playwright-bdd/issues/32
49
+ const tasks = configs.map((config, index) => {
50
+ return index === 0 ? new _gen.TestFilesGenerator(config).generate() : runInWorker(config);
51
+ });
52
+ return Promise.all(tasks);
53
+ }
54
+ async function runInWorker(config) {
55
+ const worker = new _worker_threads.Worker(GEN_WORKER_PATH, {
56
+ workerData: {
57
+ config
58
+ }
59
+ });
60
+ const [exitCode] = await (0, _events.once)(worker, 'exit');
61
+ if (exitCode) {
62
+ (0, _exit.exit)();
63
+ }
64
+ }
@@ -0,0 +1,11 @@
1
+ #!/usr/bin/env node
2
+ "use strict";
3
+
4
+ var _commander = require("commander");
5
+ var _test = require("./commands/test");
6
+ var _env = require("./commands/env");
7
+ var _export = require("./commands/export");
8
+ const program = new _commander.Command();
9
+ program.name('bddgen').description(`Playwright-bdd CLI v${(0, _env.getOwnVersion)()}`).addCommand(_test.testCommand, {
10
+ isDefault: true
11
+ }).addCommand(_export.exportCommand).addCommand(_env.envCommand).addHelpCommand(false).parse();
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.configOption = void 0;
7
+ exports.getCliConfigPath = getCliConfigPath;
8
+ var _commander = require("commander");
9
+ /**
10
+ * Config option moved to separate file as it used in test run.
11
+ */
12
+
13
+ const configOption = exports.configOption = new _commander.Option(`-c, --config <file>`, `Path to Playwright configuration file (default: playwright.config.(js|ts))`);
14
+ /**
15
+ * Helper used in test run to detect config location.
16
+ */
17
+ function getCliConfigPath() {
18
+ return new _commander.Command().allowUnknownOption().addOption(configOption).parse().getOptionValue('config');
19
+ }
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+
3
+ var _worker_threads = require("worker_threads");
4
+ var _gen = require("../gen");
5
+ /**
6
+ * Worker to generate test files with fresh require/import cache
7
+ * See: https://github.com/nodejs/modules/issues/307#issuecomment-858729422
8
+ */
9
+
10
+ async function main() {
11
+ await new _gen.TestFilesGenerator(_worker_threads.workerData.config).generate();
12
+ }
13
+ main();
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.getPlaywrightConfigDir = getPlaywrightConfigDir;
8
+ var _path = _interopRequireDefault(require("path"));
9
+ var _loadConfig = require("../playwright/loadConfig");
10
+ var _options = require("../cli/options");
11
+ /**
12
+ * Store playwright config dir in env to provide access to it in workers.
13
+ * Important that in workers there is different process.argv, that's why we save it to env.
14
+ * Config dir is needed to resolve all paths (features, step definitions).
15
+ */
16
+
17
+ /**
18
+ * Returns Playwright config dir considering cli --config option.
19
+ */
20
+ function getPlaywrightConfigDir({
21
+ resolveAndSave = false
22
+ } = {}) {
23
+ let configDir = process.env.PLAYWRIGHT_BDD_CONFIG_DIR;
24
+ if (!configDir) {
25
+ if (resolveAndSave) {
26
+ const cliConfigPath = (0, _options.getCliConfigPath)();
27
+ const playwrightConfigFile = (0, _loadConfig.resolveConfigFile)(cliConfigPath);
28
+ configDir = playwrightConfigFile ? _path.default.dirname(playwrightConfigFile) : process.cwd();
29
+ process.env.PLAYWRIGHT_BDD_CONFIG_DIR = configDir;
30
+ } else {
31
+ throw new Error(`Something went wrong: PLAYWRIGHT_BDD_CONFIG_DIR is not set.`);
32
+ }
33
+ }
34
+ return configDir;
35
+ }
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.enableEnrichReporterData = enableEnrichReporterData;
7
+ exports.getEnrichReporterData = getEnrichReporterData;
8
+ function enableEnrichReporterData() {
9
+ process.env.PLAYWRIGHT_BDD_ENRICH_REPORTER_DATA = '1';
10
+ }
11
+ function getEnrichReporterData(config) {
12
+ const enrichReporterDataFromEnv = Boolean(process.env.PLAYWRIGHT_BDD_ENRICH_REPORTER_DATA);
13
+ if (config.enrichReporterData === true) {
14
+ return true;
15
+ }
16
+ if (config.enrichReporterData === false) {
17
+ if (enrichReporterDataFromEnv) {
18
+ throw new Error([`Cucumber reports can't work with enrichReporterData = false in bdd config.`, `Please, set enrichReporterData = true OR remove it from config`, `to let it be auto-configured.`].join(' '));
19
+ }
20
+ return false;
21
+ }
22
+ return enrichReporterDataFromEnv;
23
+ }
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.getConfigFromEnv = getConfigFromEnv;
8
+ exports.getEnvConfigs = getEnvConfigs;
9
+ exports.saveConfigToEnv = saveConfigToEnv;
10
+ var _path = _interopRequireDefault(require("path"));
11
+ var _exit = require("../utils/exit");
12
+ /**
13
+ * Storing configs in env var PLAYWRIGHT_BDD_CONFIGS as JSON-stringified values.
14
+ * For passing configs to playwright workers and bddgen.
15
+ */
16
+
17
+ function saveConfigToEnv(config) {
18
+ const envConfigs = getEnvConfigs();
19
+ const existingConfig = envConfigs[config.outputDir];
20
+ if (existingConfig) {
21
+ // Playwright config can be evaluated several times.
22
+ // Throw error only if different calls of defineBddConfig() use the same outputDir.
23
+ // See: https://github.com/vitalets/playwright-bdd/issues/39#issuecomment-1653805368
24
+ if (!isSameConfigs(config, existingConfig)) {
25
+ (0, _exit.exit)(`When using several calls of defineBddConfig()`, `please manually provide different "outputDir" option.`);
26
+ }
27
+ return;
28
+ }
29
+ envConfigs[config.outputDir] = config;
30
+ saveEnvConfigs(envConfigs);
31
+ }
32
+ function getConfigFromEnv(outputDir) {
33
+ const envConfigs = getEnvConfigs();
34
+ outputDir = _path.default.resolve(outputDir);
35
+ const config = envConfigs[outputDir];
36
+ if (!config) {
37
+ // exit(`Config not found for outputDir: "${outputDir}".`, `Available dirs: ${Object.keys(envConfigs).join('\n')}`);
38
+ return {};
39
+ }
40
+ return config;
41
+ }
42
+ function getEnvConfigs() {
43
+ return JSON.parse(process.env.PLAYWRIGHT_BDD_CONFIGS || '{}');
44
+ }
45
+ function saveEnvConfigs(envConfigs) {
46
+ process.env.PLAYWRIGHT_BDD_CONFIGS = JSON.stringify(envConfigs);
47
+ }
48
+ function isSameConfigs(config1, config2) {
49
+ return JSON.stringify(config1) === JSON.stringify(config2);
50
+ }
@@ -0,0 +1,94 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.defaults = void 0;
8
+ exports.defineBddConfig = defineBddConfig;
9
+ exports.extractCucumberConfig = extractCucumberConfig;
10
+ var _path = _interopRequireDefault(require("path"));
11
+ var _env = require("./env");
12
+ var _configDir = require("./configDir");
13
+ var _utils = require("../utils");
14
+ /**
15
+ * BDD Config.
16
+ */
17
+
18
+ const defaults = exports.defaults = {
19
+ outputDir: '.features-gen',
20
+ verbose: false,
21
+ examplesTitleFormat: 'Example #<_index_>',
22
+ publishQuiet: true,
23
+ quotes: 'double'
24
+ };
25
+ function defineBddConfig(inputConfig) {
26
+ const isMainProcess = !process.env.TEST_WORKER_INDEX;
27
+ const configDir = (0, _configDir.getPlaywrightConfigDir)({
28
+ resolveAndSave: isMainProcess
29
+ });
30
+ const config = getConfig(configDir, inputConfig);
31
+ // In main process store config in env to be accessible by workers
32
+ if (isMainProcess) {
33
+ (0, _env.saveConfigToEnv)(config);
34
+ }
35
+ return config.outputDir;
36
+ }
37
+ function getConfig(configDir, inputConfig) {
38
+ const config = Object.assign({}, defaults, inputConfig);
39
+ const featuresRoot = config.featuresRoot ? _path.default.resolve(configDir, config.featuresRoot) : configDir;
40
+ return {
41
+ ...config,
42
+ // important to resolve outputDir as it is used as unique key for input configs
43
+ outputDir: _path.default.resolve(configDir, config.outputDir),
44
+ importTestFrom: resolveImportTestFrom(configDir, config.importTestFrom),
45
+ featuresRoot
46
+ };
47
+ }
48
+ function extractCucumberConfig(config) {
49
+ // todo: find more strict way to omit own config fields
50
+ // see: https://bobbyhadz.com/blog/typescript-object-remove-property
51
+ const omitProps = {
52
+ outputDir: true,
53
+ importTestFrom: true,
54
+ verbose: true,
55
+ skip: true,
56
+ examplesTitleFormat: true,
57
+ quotes: true,
58
+ tags: true,
59
+ featuresRoot: true,
60
+ enrichReporterData: true
61
+ };
62
+ const keys = Object.keys(omitProps);
63
+ const cucumberConfig = {
64
+ ...config
65
+ };
66
+ keys.forEach(key => delete cucumberConfig[key]);
67
+ stripPublishQuiet(cucumberConfig);
68
+ return cucumberConfig;
69
+ }
70
+ function resolveImportTestFrom(configDir, importTestFrom) {
71
+ if (importTestFrom) {
72
+ const {
73
+ file,
74
+ varName
75
+ } = typeof importTestFrom === 'string' ? {
76
+ file: importTestFrom
77
+ } : importTestFrom;
78
+ return {
79
+ file: _path.default.resolve(configDir, file),
80
+ varName
81
+ };
82
+ }
83
+ }
84
+ function stripPublishQuiet(cucumberConfig) {
85
+ const cucumberVersion = (0, _utils.getPackageVersion)('@cucumber/cucumber');
86
+ // Playwright-bdd supports Cucumber from v9+
87
+ // publishQuiet was deprecated in Cucumber 9.4.0.
88
+ // See: https://github.com/cucumber/cucumber-js/pull/2311
89
+ // Remove publishQuite from Cucumber config to hide deprecation warning.
90
+ // See: https://github.com/vitalets/playwright-bdd/pull/47
91
+ if (!/^9\.[0123]\./.test(cucumberVersion)) {
92
+ delete cucumberConfig.publishQuiet;
93
+ }
94
+ }
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.LANG_EN = void 0;
7
+ exports.isEnglish = isEnglish;
8
+ /**
9
+ * Helpers for Cucumber language option.
10
+ */
11
+ const LANG_EN = exports.LANG_EN = 'en';
12
+ function isEnglish(lang) {
13
+ return !lang || lang === LANG_EN;
14
+ }
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.buildStepDefinition = buildStepDefinition;
8
+ var _messages = require("@cucumber/messages");
9
+ var _cucumberExpressions = require("@cucumber/cucumber-expressions");
10
+ var _step_definition = _interopRequireDefault(require("@cucumber/cucumber/lib/models/step_definition"));
11
+ /**
12
+ * Extracted from cucumber SupportCodeLibraryBuilder.
13
+ * See: https://github.com/cucumber/cucumber-js/blob/main/src/support_code_library_builder/index.ts
14
+ */
15
+
16
+ const newId = _messages.IdGenerator.uuid();
17
+ function buildStepDefinition({
18
+ keyword,
19
+ pattern,
20
+ code,
21
+ line,
22
+ options,
23
+ uri
24
+ }, supportCodeLibrary) {
25
+ // todo: handle error.undefinedParameterTypeName as it's done in cucumber?
26
+ const expression = typeof pattern === 'string' ? new _cucumberExpressions.CucumberExpression(pattern, supportCodeLibrary.parameterTypeRegistry) : new _cucumberExpressions.RegularExpression(pattern, supportCodeLibrary.parameterTypeRegistry);
27
+ // skip wrapping code as it is not needed for decorator steps
28
+ // const wrappedCode = this.wrapCode({
29
+ // code,
30
+ // wrapperOptions: options.wrapperOptions,
31
+ // })
32
+ return new _step_definition.default({
33
+ code,
34
+ expression,
35
+ id: newId(),
36
+ line,
37
+ options,
38
+ keyword,
39
+ pattern,
40
+ unwrappedCode: code,
41
+ uri
42
+ });
43
+ }
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.createTestStep = createTestStep;
7
+ /**
8
+ * Creates partial TestStep for usage in reporter.
9
+ * It is partial, b/c final pickleStepId will be known only in reporter.
10
+ *
11
+ * See: https://github.com/cucumber/cucumber-js/blob/main/src/runtime/assemble_test_cases.ts#L93
12
+ */
13
+ function createTestStep(stepDefinition, stepText) {
14
+ const result = stepDefinition.expression.match(stepText);
15
+ if (!result) {
16
+ // this should not happen as stepDefinition is already matched
17
+ throw Error(`Step definition didn't match step "${stepText}"`);
18
+ }
19
+ const stepMatchArguments = result.map(arg => {
20
+ return {
21
+ group: mapArgumentGroup(arg.group),
22
+ parameterTypeName: arg.parameterType.name
23
+ };
24
+ });
25
+ return {
26
+ // id will be generated in reporter, no need to generate it here
27
+ id: '',
28
+ // looks like it's useless to store stepDefinitionIds here
29
+ // b/c they will be different in reporter
30
+ // stepDefinitionIds: [stepDefinition.id],
31
+ stepMatchArgumentsLists: [{
32
+ stepMatchArguments
33
+ }]
34
+ };
35
+ }
36
+ function mapArgumentGroup(group) {
37
+ var _group$children;
38
+ return {
39
+ start: group.start,
40
+ value: group.value,
41
+ children: (_group$children = group.children) === null || _group$children === void 0 ? void 0 : _group$children.map(child => mapArgumentGroup(child))
42
+ };
43
+ }