@zohodesk/testinglibrary 0.0.7 → 0.0.8-n20-experimental

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 (160) hide show
  1. package/.babelrc +7 -2
  2. package/.eslintrc.js +5 -1
  3. package/.gitlab-ci.yml +206 -0
  4. package/README.md +172 -1
  5. package/build/common/data-generator/steps/DataGenerator.spec.js +19 -0
  6. package/build/common/data-generator/steps/DataGeneratorStepsHelper.js +19 -0
  7. package/build/common/multi-actor/steps/multiActorHandling.spec.js +26 -0
  8. package/build/common/searchFake/helpers/rpcRequestHelper.js +52 -0
  9. package/build/common/searchFake/steps/searchFake.spec.js +77 -0
  10. package/build/core/dataGenerator/DataGenerator.js +108 -0
  11. package/build/core/dataGenerator/DataGeneratorError.js +50 -0
  12. package/build/core/dataGenerator/DataGeneratorHelper.js +49 -0
  13. package/build/core/jest/preprocessor/jsPreprocessor.js +3 -9
  14. package/build/core/jest/setup/index.js +1 -7
  15. package/build/core/playwright/builtInFixtures/actorContext.js +75 -0
  16. package/build/core/playwright/builtInFixtures/addTags.js +19 -0
  17. package/build/core/playwright/builtInFixtures/cacheLayer.js +13 -0
  18. package/build/core/playwright/builtInFixtures/context.js +32 -0
  19. package/build/core/playwright/builtInFixtures/executionContext.js +17 -0
  20. package/build/core/playwright/builtInFixtures/i18N.js +41 -0
  21. package/build/core/playwright/builtInFixtures/index.js +46 -0
  22. package/build/core/playwright/builtInFixtures/page.js +38 -0
  23. package/build/core/playwright/builtInFixtures/unauthenticatedPage.js +18 -0
  24. package/build/core/playwright/clear-caches.js +49 -0
  25. package/build/core/playwright/codegen.js +4 -4
  26. package/build/core/playwright/configuration/Configuration.js +25 -0
  27. package/build/core/playwright/configuration/ConfigurationHelper.js +43 -0
  28. package/build/core/playwright/configuration/UserArgs.js +12 -0
  29. package/build/core/playwright/constants/browserTypes.js +12 -0
  30. package/build/core/playwright/constants/fileMutexConfig.js +9 -0
  31. package/build/core/playwright/custom-commands.js +1 -2
  32. package/build/core/playwright/env-initializer.js +28 -6
  33. package/build/core/playwright/fixtures.js +24 -0
  34. package/build/core/playwright/helpers/additionalProfiles.js +25 -0
  35. package/build/core/playwright/helpers/auth/accountLogin.js +21 -0
  36. package/build/core/playwright/helpers/auth/checkAuthCookies.js +41 -0
  37. package/build/core/playwright/helpers/auth/getUrlOrigin.js +13 -0
  38. package/build/core/playwright/helpers/auth/getUsers.js +118 -0
  39. package/build/core/playwright/helpers/auth/index.js +76 -0
  40. package/build/core/playwright/helpers/auth/loginDefaultStepsHelper.js +54 -0
  41. package/build/core/playwright/helpers/auth/loginSteps.js +50 -0
  42. package/build/core/playwright/helpers/checkAuthDirectory.js +27 -0
  43. package/build/core/playwright/helpers/configFileNameProvider.js +31 -0
  44. package/build/core/playwright/helpers/customFixturesHelper.js +58 -0
  45. package/build/core/playwright/helpers/fileMutex.js +71 -0
  46. package/build/core/playwright/helpers/getUserFixtures.js +23 -0
  47. package/build/core/playwright/helpers/mergeObjects.js +13 -0
  48. package/build/core/playwright/helpers/parseUserArgs.js +10 -0
  49. package/build/core/playwright/index.js +10 -98
  50. package/build/core/playwright/readConfigFile.js +93 -14
  51. package/build/core/playwright/report-generator.js +9 -8
  52. package/build/core/playwright/runner/Runner.js +22 -0
  53. package/build/core/playwright/runner/RunnerHelper.js +43 -0
  54. package/build/core/playwright/runner/RunnerTypes.js +17 -0
  55. package/build/core/playwright/runner/SpawnRunner.js +113 -0
  56. package/build/core/playwright/setup/Project.js +35 -0
  57. package/build/core/playwright/setup/ProjectConfiguration.js +80 -0
  58. package/build/core/playwright/setup/config-creator.js +75 -103
  59. package/build/core/playwright/setup/config-utils.js +188 -0
  60. package/build/core/playwright/setup/custom-reporter.js +136 -0
  61. package/build/core/playwright/setup/qc-custom-reporter.js +291 -0
  62. package/build/core/playwright/tagProcessor.js +69 -0
  63. package/build/core/playwright/test-runner.js +84 -98
  64. package/build/core/playwright/types.js +44 -0
  65. package/build/core/playwright/validateFeature.js +28 -0
  66. package/build/decorators.d.ts +1 -1
  67. package/build/decorators.js +1 -1
  68. package/build/index.d.ts +76 -3
  69. package/build/index.js +63 -17
  70. package/build/lib/cli.js +28 -4
  71. package/build/lib/post-install.js +19 -11
  72. package/build/parser/parser.js +0 -1
  73. package/build/setup-folder-structure/helper.js +37 -0
  74. package/build/setup-folder-structure/reportEnhancement/addonScript.html +25 -0
  75. package/build/setup-folder-structure/reportEnhancement/reportAlteration.js +25 -0
  76. package/build/setup-folder-structure/samples/accountLogin-sample.js +19 -0
  77. package/build/setup-folder-structure/samples/actors-index.js +2 -0
  78. package/build/setup-folder-structure/samples/auth-setup-sample.js +10 -67
  79. package/build/setup-folder-structure/samples/editions-index.js +3 -0
  80. package/build/setup-folder-structure/samples/free-sample.json +25 -0
  81. package/build/setup-folder-structure/samples/git-ignore.sample.js +8 -4
  82. package/build/setup-folder-structure/samples/settings.json +7 -0
  83. package/build/setup-folder-structure/samples/testSetup-sample.js +14 -0
  84. package/build/setup-folder-structure/samples/uat-config-sample.js +13 -2
  85. package/build/setup-folder-structure/setupProject.js +34 -12
  86. package/build/test/core/playwright/__tests__/tagProcessor.test.js +94 -0
  87. package/build/test/core/playwright/__tests__/validateFeature.test.js +69 -0
  88. package/build/test/core/playwright/buildInFixtures/__tests__/executionContext.test.js +27 -0
  89. package/build/test/core/playwright/configuration/__tests__/Configuration.test.js +53 -0
  90. package/build/test/core/playwright/helpers/__tests__/additionalProfiles.test.js +45 -0
  91. package/build/test/core/playwright/helpers/__tests__/configFileNameProvider.test.js +34 -0
  92. package/build/test/core/playwright/helpers/__tests__/customFixturesHelper.test.js +51 -0
  93. package/build/test/core/playwright/helpers/__tests__/fileMutex.test.js +79 -0
  94. package/build/test/core/playwright/helpers/__tests__/getUsers_ListOfActors.test.js +80 -0
  95. package/build/test/core/playwright/runner/__tests__/RunnerHelper.test.js +16 -0
  96. package/build/test/core/playwright/runner/__tests__/SpawnRunner.test.js +27 -0
  97. package/build/utils/cliArgsToObject.js +8 -1
  98. package/build/utils/commonUtils.js +17 -0
  99. package/build/utils/fileUtils.js +60 -4
  100. package/build/utils/logger.js +1 -31
  101. package/build/utils/rootPath.js +16 -9
  102. package/build/utils/stepDefinitionsFormatter.js +1 -2
  103. package/changelog.md +167 -0
  104. package/jest.config.js +29 -11
  105. package/npm-shrinkwrap.json +9610 -6631
  106. package/package.json +34 -27
  107. package/playwright.config.js +0 -50
  108. package/test-results/.last-run.json +4 -0
  109. package/unit_reports/unit-report.html +277 -0
  110. package/Changelog.md +0 -42
  111. package/build/bdd-framework/cli/commands/env.js +0 -43
  112. package/build/bdd-framework/cli/commands/export.js +0 -48
  113. package/build/bdd-framework/cli/commands/test.js +0 -59
  114. package/build/bdd-framework/cli/index.js +0 -11
  115. package/build/bdd-framework/cli/options.js +0 -20
  116. package/build/bdd-framework/cli/worker.js +0 -13
  117. package/build/bdd-framework/config/dir.js +0 -27
  118. package/build/bdd-framework/config/env.js +0 -49
  119. package/build/bdd-framework/config/index.js +0 -91
  120. package/build/bdd-framework/cucumber/buildStepDefinition.js +0 -43
  121. package/build/bdd-framework/cucumber/gherkin.d.js +0 -5
  122. package/build/bdd-framework/cucumber/gherkin.d.ts +0 -45
  123. package/build/bdd-framework/cucumber/loadConfig.js +0 -17
  124. package/build/bdd-framework/cucumber/loadFeatures.js +0 -39
  125. package/build/bdd-framework/cucumber/loadSnippetBuilder.js +0 -20
  126. package/build/bdd-framework/cucumber/loadSources.js +0 -57
  127. package/build/bdd-framework/cucumber/loadSteps.js +0 -35
  128. package/build/bdd-framework/decorators.js +0 -22
  129. package/build/bdd-framework/gen/formatter.js +0 -88
  130. package/build/bdd-framework/gen/i18n.js +0 -35
  131. package/build/bdd-framework/gen/index.js +0 -160
  132. package/build/bdd-framework/gen/poms.js +0 -46
  133. package/build/bdd-framework/gen/testFile.js +0 -356
  134. package/build/bdd-framework/gen/testNode.js +0 -48
  135. package/build/bdd-framework/gen/testPoms.js +0 -123
  136. package/build/bdd-framework/index.js +0 -45
  137. package/build/bdd-framework/playwright/fixtureParameterNames.js +0 -77
  138. package/build/bdd-framework/playwright/getLocationInFile.js +0 -46
  139. package/build/bdd-framework/playwright/loadConfig.js +0 -42
  140. package/build/bdd-framework/playwright/testTypeImpl.js +0 -41
  141. package/build/bdd-framework/playwright/transform.js +0 -80
  142. package/build/bdd-framework/playwright/types.js +0 -5
  143. package/build/bdd-framework/playwright/utils.js +0 -34
  144. package/build/bdd-framework/run/bddFixtures.js +0 -108
  145. package/build/bdd-framework/run/bddWorld.js +0 -87
  146. package/build/bdd-framework/snippets/index.js +0 -131
  147. package/build/bdd-framework/snippets/snippetSyntax.js +0 -41
  148. package/build/bdd-framework/snippets/snippetSyntaxDecorators.js +0 -26
  149. package/build/bdd-framework/snippets/snippetSyntaxTs.js +0 -18
  150. package/build/bdd-framework/stepDefinitions/createBdd.js +0 -49
  151. package/build/bdd-framework/stepDefinitions/createDecorators.js +0 -109
  152. package/build/bdd-framework/stepDefinitions/decorators/poms.js +0 -50
  153. package/build/bdd-framework/stepDefinitions/decorators/steps.js +0 -94
  154. package/build/bdd-framework/stepDefinitions/defineStep.js +0 -61
  155. package/build/bdd-framework/stepDefinitions/stepConfig.js +0 -24
  156. package/build/bdd-framework/utils/index.js +0 -50
  157. package/build/bdd-framework/utils/jsStringWrap.js +0 -44
  158. package/build/bdd-framework/utils/logger.js +0 -29
  159. package/build/setup-folder-structure/samples/authUsers-sample.json +0 -9
  160. package/build/setup-folder-structure/samples/env-config-sample.json +0 -21
@@ -1,59 +0,0 @@
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 _utils = require("../../utils");
15
- var _loadConfig = require("../../playwright/loadConfig");
16
- var _env = require("../../config/env");
17
- var _config = require("../../config");
18
- var _options = require("../options");
19
- const GEN_WORKER_PATH = _path.default.resolve(__dirname, '..', 'worker.js');
20
- const 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 = Object.values((0, _env.getEnvConfigs)());
23
- assertConfigsCount(configs);
24
- const cliOptions = buildCliOptions(opts);
25
- await generateFilesForConfigs(configs, cliOptions);
26
- });
27
- exports.testCommand = testCommand;
28
- function buildCliOptions(opts) {
29
- const config = {};
30
- if ('tags' in opts) config.tags = opts.tags;
31
- if ('verbose' in opts) config.verbose = Boolean(opts.verbose);
32
- return config;
33
- }
34
- function assertConfigsCount(configs) {
35
- if (configs.length === 0) {
36
- (0, _utils.exitWithMessage)(`No BDD configs found. Did you use defineBddConfig() in playwright.config.ts?`);
37
- }
38
- }
39
- async function generateFilesForConfigs(configs, cliConfig) {
40
- // run first config in main thread and other in workers (to have fresh require cache)
41
- // See: https://github.com/vitalets/playwright-bdd/issues/32
42
- const tasks = configs.map((config, index) => {
43
- const finalConfig = {
44
- ...config,
45
- ...cliConfig
46
- };
47
- return index === 0 ? new _gen.TestFilesGenerator(finalConfig).generate() : runInWorker(finalConfig);
48
- });
49
- return Promise.all(tasks);
50
- }
51
- async function runInWorker(config) {
52
- const worker = new _worker_threads.Worker(GEN_WORKER_PATH, {
53
- workerData: {
54
- config
55
- }
56
- });
57
- // todo: check if worker exited with error?
58
- await (0, _events.once)(worker, 'exit');
59
- }
@@ -1,11 +0,0 @@
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();
@@ -1,20 +0,0 @@
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 = 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
- exports.configOption = configOption;
18
- function getCliConfigPath() {
19
- return new _commander.Command().allowUnknownOption().addOption(configOption).parse().getOptionValue('config');
20
- }
@@ -1,13 +0,0 @@
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();
@@ -1,27 +0,0 @@
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.
15
- */
16
-
17
- /**
18
- * Resolve playwright config dir considering cli flags.
19
- */
20
- function getPlaywrightConfigDir() {
21
- if (!process.env.PLAYWRIGHT_BDD_CONFIG_DIR) {
22
- const cliConfigPath = (0, _options.getCliConfigPath)();
23
- const playwrightConfigFile = (0, _loadConfig.resolveConfigFile)(cliConfigPath);
24
- process.env.PLAYWRIGHT_BDD_CONFIG_DIR = playwrightConfigFile ? _path.default.dirname(playwrightConfigFile) : process.cwd();
25
- }
26
- return process.env.PLAYWRIGHT_BDD_CONFIG_DIR;
27
- }
@@ -1,49 +0,0 @@
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 _utils = require("../utils");
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, _utils.exitWithMessage)(`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
- (0, _utils.exitWithMessage)(`Config not found for outputDir: "${outputDir}".`, `Available dirs: ${Object.keys(envConfigs).join('\n')}`);
38
- }
39
- return config;
40
- }
41
- function getEnvConfigs() {
42
- return JSON.parse(process.env.PLAYWRIGHT_BDD_CONFIGS || '{}');
43
- }
44
- function saveEnvConfigs(envConfigs) {
45
- process.env.PLAYWRIGHT_BDD_CONFIGS = JSON.stringify(envConfigs);
46
- }
47
- function isSameConfigs(config1, config2) {
48
- return JSON.stringify(config1) === JSON.stringify(config2);
49
- }
@@ -1,91 +0,0 @@
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 _dir = require("./dir");
13
- var _utils = require("../utils");
14
- /**
15
- * BDD Config.
16
- */
17
-
18
- const defaults = {
19
- outputDir: '.features-gen',
20
- verbose: false,
21
- examplesTitleFormat: 'Example #<_index_>',
22
- publishQuiet: true,
23
- quotes: 'double'
24
- };
25
- exports.defaults = defaults;
26
- function defineBddConfig(inputConfig) {
27
- const config = getConfig(inputConfig);
28
- // In main process store config in env to be accessible by workers
29
- if (!process.env.TEST_WORKER_INDEX) {
30
- (0, _env.saveConfigToEnv)(config);
31
- }
32
- return config.outputDir;
33
- }
34
- function getConfig(inputConfig) {
35
- const config = Object.assign({}, defaults, inputConfig);
36
- const configDir = (0, _dir.getPlaywrightConfigDir)();
37
- const featuresRoot = config.featuresRoot ? _path.default.resolve(configDir, config.featuresRoot) : configDir;
38
- return {
39
- ...config,
40
- // important to resolve outputDir as it is used as unique key for input configs
41
- outputDir: _path.default.resolve(configDir, config.outputDir),
42
- importTestFrom: resolveImportTestFrom(configDir, config.importTestFrom),
43
- featuresRoot
44
- };
45
- }
46
- function extractCucumberConfig(config) {
47
- // todo: find more strict way to omit own config fields
48
- // see: https://bobbyhadz.com/blog/typescript-object-remove-property
49
- const omitProps = {
50
- outputDir: true,
51
- importTestFrom: true,
52
- verbose: true,
53
- skip: true,
54
- examplesTitleFormat: true,
55
- quotes: true,
56
- tags: true,
57
- featuresRoot: true
58
- };
59
- const keys = Object.keys(omitProps);
60
- const cucumberConfig = {
61
- ...config
62
- };
63
- keys.forEach(key => delete cucumberConfig[key]);
64
- stripPublishQuiet(cucumberConfig);
65
- return cucumberConfig;
66
- }
67
- function resolveImportTestFrom(configDir, importTestFrom) {
68
- if (importTestFrom) {
69
- const {
70
- file,
71
- varName
72
- } = typeof importTestFrom === 'string' ? {
73
- file: importTestFrom
74
- } : importTestFrom;
75
- return {
76
- file: _path.default.resolve(configDir, file),
77
- varName
78
- };
79
- }
80
- }
81
- function stripPublishQuiet(cucumberConfig) {
82
- const cucumberVersion = (0, _utils.getPackageVersion)('@cucumber/cucumber');
83
- // Playwright-bdd supports Cucumber from v9+
84
- // publishQuiet was deprecated in Cucumber 9.4.0.
85
- // See: https://github.com/cucumber/cucumber-js/pull/2311
86
- // Remove publishQuite from Cucumber config to hide deprecation warning.
87
- // See: https://github.com/vitalets/playwright-bdd/pull/47
88
- if (!/^9\.[0123]\./.test(cucumberVersion)) {
89
- delete cucumberConfig.publishQuiet;
90
- }
91
- }
@@ -1,43 +0,0 @@
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
- }
@@ -1,5 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
@@ -1,45 +0,0 @@
1
- /**
2
- * Copied from @cucumber/cucumber/lib/api/gherkin.d.ts
3
- * Fixes error:
4
- * Return type of exported function has or is using name 'PickleWithDocument'
5
- * from external module "../node_modules/@cucumber/cucumber/lib/api/gherkin"
6
- * but cannot be named
7
- */
8
- import {
9
- Envelope,
10
- GherkinDocument,
11
- IdGenerator,
12
- Location,
13
- ParseError,
14
- Pickle,
15
- } from '@cucumber/messages';
16
- import { ISourcesCoordinates } from '@cucumber/cucumber/lib/api/types';
17
- import { ILogger } from '@cucumber/cucumber/lib/logger';
18
-
19
- declare module '@cucumber/cucumber/lib/api/gherkin' {
20
- export interface PickleWithDocument {
21
- gherkinDocument: GherkinDocument;
22
- location: Location;
23
- pickle: Pickle;
24
- }
25
- export function getFilteredPicklesAndErrors({
26
- newId,
27
- cwd,
28
- logger,
29
- unexpandedFeaturePaths,
30
- featurePaths,
31
- coordinates,
32
- onEnvelope,
33
- }: {
34
- newId: IdGenerator.NewId;
35
- cwd: string;
36
- logger: ILogger;
37
- unexpandedFeaturePaths: string[];
38
- featurePaths: string[];
39
- coordinates: ISourcesCoordinates;
40
- onEnvelope?: (envelope: Envelope) => void;
41
- }): Promise<{
42
- filteredPickles: PickleWithDocument[];
43
- parseErrors: ParseError[];
44
- }>;
45
- }
@@ -1,17 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.loadConfig = loadConfig;
7
- var _api = require("@cucumber/cucumber/api");
8
- const cache = new Map();
9
- async function loadConfig(options, environment) {
10
- const cacheKey = JSON.stringify(options);
11
- let config = cache.get(cacheKey);
12
- if (!config) {
13
- config = (0, _api.loadConfiguration)(options, environment);
14
- cache.set(cacheKey, config);
15
- }
16
- return config;
17
- }
@@ -1,39 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.loadFeatures = loadFeatures;
7
- var _loadSources = require("./loadSources");
8
- var _utils = require("../utils");
9
- async function loadFeatures(runConfiguration, environment) {
10
- const {
11
- filteredPickles,
12
- parseErrors
13
- } = await (0, _loadSources.loadSources)(runConfiguration.sources, environment);
14
- handleParseErrors(parseErrors);
15
- return groupByDocument(filteredPickles);
16
- }
17
- function groupByDocument(filteredPickles) {
18
- const features = new Map();
19
- filteredPickles.forEach(({
20
- pickle,
21
- gherkinDocument
22
- }) => {
23
- let pickles = features.get(gherkinDocument);
24
- if (!pickles) {
25
- pickles = [];
26
- features.set(gherkinDocument, pickles);
27
- }
28
- pickles.push(pickle);
29
- });
30
- return features;
31
- }
32
- function handleParseErrors(parseErrors) {
33
- if (parseErrors.length) {
34
- const message = parseErrors.map(parseError => {
35
- return `Parse error in "${parseError.source.uri}" ${parseError.message}`;
36
- }).join('\n');
37
- (0, _utils.exitWithMessage)(message);
38
- }
39
- }
@@ -1,20 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.loadSnippetBuilder = loadSnippetBuilder;
7
- var _cucumber = require("@cucumber/cucumber");
8
- /**
9
- * Loads snippet builder
10
- * See: https://github.com/cucumber/cucumber-js/blob/main/src/formatter/builder.ts
11
- */
12
-
13
- async function loadSnippetBuilder(supportCodeLibrary, snippetInterface, snippetSyntax) {
14
- return _cucumber.FormatterBuilder.getStepDefinitionSnippetBuilder({
15
- cwd: process.cwd(),
16
- snippetInterface,
17
- snippetSyntax,
18
- supportCodeLibrary
19
- });
20
- }
@@ -1,57 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.loadSources = loadSources;
7
- var _paths = require("@cucumber/cucumber/lib/api/paths");
8
- var _messages = require("@cucumber/messages");
9
- var _environment = require("@cucumber/cucumber/lib/api/environment");
10
- var _gherkin = require("@cucumber/cucumber/lib/api/gherkin");
11
- var _console_logger = require("@cucumber/cucumber/lib/api/console_logger");
12
- /**
13
- * Copied from original load_sources, but returns full Pickles.
14
- * See: https://github.com/cucumber/cucumber-js/blob/main/src/api/load_sources.ts
15
- */
16
-
17
- /**
18
- * Load and parse features, produce a filtered and ordered test plan and/or parse errors.
19
- *
20
- * @public
21
- * @param coordinates - Coordinates required to find features
22
- * @param environment - Project environment.
23
- */
24
- async function loadSources(coordinates, environment = {}) {
25
- const {
26
- cwd,
27
- stderr,
28
- debug
29
- } = (0, _environment.mergeEnvironment)(environment);
30
- const logger = new _console_logger.ConsoleLogger(stderr, debug);
31
- const newId = _messages.IdGenerator.uuid();
32
- const {
33
- unexpandedFeaturePaths,
34
- featurePaths
35
- } = await (0, _paths.resolvePaths)(logger, cwd, coordinates);
36
- if (featurePaths.length === 0) {
37
- return {
38
- filteredPickles: [],
39
- parseErrors: []
40
- };
41
- }
42
- const {
43
- filteredPickles,
44
- parseErrors
45
- } = await (0, _gherkin.getFilteredPicklesAndErrors)({
46
- newId,
47
- cwd,
48
- logger,
49
- unexpandedFeaturePaths,
50
- featurePaths,
51
- coordinates
52
- });
53
- return {
54
- filteredPickles,
55
- parseErrors
56
- };
57
- }
@@ -1,35 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.findStepDefinition = findStepDefinition;
7
- exports.hasTsNodeRegister = hasTsNodeRegister;
8
- exports.loadSteps = loadSteps;
9
- var _api = require("@cucumber/cucumber/api");
10
- var _utils = require("../utils");
11
- var _transform = require("../playwright/transform");
12
- const cache = new Map();
13
- async function loadSteps(runConfiguration, environment = {}) {
14
- const cacheKey = JSON.stringify(runConfiguration);
15
- let lib = cache.get(cacheKey);
16
- if (!lib) {
17
- // use Playwright's built-in hook to compile TypeScript steps
18
- const uninstall = !hasTsNodeRegister(runConfiguration) ? (0, _transform.installTransform)() : () => {};
19
- lib = (0, _api.loadSupport)(runConfiguration, environment).finally(() => uninstall());
20
- cache.set(cacheKey, lib);
21
- }
22
- return lib;
23
- }
24
- function findStepDefinition(supportCodeLibrary, stepText, file) {
25
- const matchedSteps = supportCodeLibrary.stepDefinitions.filter(step => {
26
- return step.matchesStepName(stepText);
27
- });
28
- if (matchedSteps.length === 0) return;
29
- if (matchedSteps.length > 1) (0, _utils.exitWithMessage)([`Several step definitions found for text: ${stepText} (${file})`, ...matchedSteps.map(s => `- ${s.pattern}`)].join('\n'));
30
- // todo: check stepDefinition.keyword with PickleStepType
31
- return matchedSteps[0];
32
- }
33
- function hasTsNodeRegister(runConfiguration) {
34
- return runConfiguration.support.requireModules.includes('ts-node/register');
35
- }
@@ -1,22 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- Object.defineProperty(exports, "Fixture", {
7
- enumerable: true,
8
- get: function () {
9
- return _poms.Fixture;
10
- }
11
- });
12
- exports.When = exports.Then = exports.Step = exports.Given = void 0;
13
- var _poms = require("./stepDefinitions/decorators/poms");
14
- var _steps = require("./stepDefinitions/decorators/steps");
15
- const Given = (0, _steps.createStepDecorator)('Given');
16
- exports.Given = Given;
17
- const When = (0, _steps.createStepDecorator)('When');
18
- exports.When = When;
19
- const Then = (0, _steps.createStepDecorator)('Then');
20
- exports.Then = Then;
21
- const Step = (0, _steps.createStepDecorator)('Unknown');
22
- exports.Step = Step;
@@ -1,88 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.Formatter = void 0;
7
- var _jsStringWrap = require("../utils/jsStringWrap");
8
- /**
9
- * Helper to format Playwright test file.
10
- */
11
-
12
- const TAGS_FIXTURE_TEST_KEY_SEPARATOR = '|';
13
- class Formatter {
14
- config;
15
- constructor(config) {
16
- this.config = config;
17
- }
18
- fileHeader(uri, importTestFrom) {
19
- const file = (importTestFrom === null || importTestFrom === void 0 ? void 0 : importTestFrom.file) || '@zohodesk/testinglibrary';
20
- let varName = (importTestFrom === null || importTestFrom === void 0 ? void 0 : importTestFrom.varName) || 'test';
21
- if (varName !== 'test') varName = `${varName} as test`;
22
- return [`/** Generated from: ${uri} */`,
23
- // this.quoted() is not possible for 'import from' as backticks not parsed
24
- `import { ${varName} } from ${JSON.stringify(file)};`, ''];
25
- }
26
- suite(node, children) {
27
- // prettier-ignore
28
- return [`test.describe${this.getSubFn(node)}(${this.quoted(node.title)}, () => {`, '', ...children.map(indent), `});`, ''];
29
- }
30
- beforeEach(fixtures, children) {
31
- const fixturesStr = [...fixtures].join(', ');
32
- // prettier-ignore
33
- return [`test.beforeEach(async ({ ${fixturesStr} }) => {`, ...children.map(indent), `});`, ''];
34
- }
35
- test(node, fixtures, children) {
36
- const fixturesStr = [...fixtures].join(', ');
37
- // prettier-ignore
38
- return [`test${this.getSubFn(node)}(${this.quoted(node.title)}, async ({ ${fixturesStr} }) => {`, ...children.map(indent), `});`, ''];
39
- }
40
- // eslint-disable-next-line max-params
41
- step(keyword, text, argument, fixtureNames = []) {
42
- const fixtures = fixtureNames.length ? `{ ${fixtureNames.join(', ')} }` : '';
43
- const argumentArg = argument ? JSON.stringify(argument) : fixtures ? 'null' : '';
44
- const textArg = this.quoted(text);
45
- const args = [textArg, argumentArg, fixtures].filter(arg => arg !== '').join(', ');
46
- return `await ${keyword}(${args});`;
47
- }
48
- missingStep(keyword, text) {
49
- return `// missing step: ${keyword}(${this.quoted(text)});`;
50
- }
51
- useFixtures(fixtures) {
52
- return fixtures.length > 0 ? ['// == technical section ==', '', 'test.use({', ...fixtures.map(indent), '});'] : [];
53
- }
54
- testFixture() {
55
- return ['$test: ({}, use) => use(test),'];
56
- }
57
- tagsFixture(testNodes) {
58
- const lines = testNodes.filter(node => node.tags.length).map(node => {
59
- // remove first parent as it is the same for all tests: root suite
60
- const key = node.titlePath.slice(1).join(TAGS_FIXTURE_TEST_KEY_SEPARATOR);
61
- return `${JSON.stringify(key)}: ${JSON.stringify(node.tags)},`;
62
- });
63
- return lines.length > 0 ? ['$tags: ({}, use, testInfo) => use({', ...lines.map(indent),
64
- // .slice(2) -> b/c we remove filename and root suite title
65
- `}[testInfo.titlePath.slice(2).join(${JSON.stringify(TAGS_FIXTURE_TEST_KEY_SEPARATOR)})] || []),`] : [];
66
- }
67
- getSubFn(node) {
68
- if (node.flags.only) return '.only';
69
- if (node.flags.skip) return '.skip';
70
- if (node.flags.fixme) return '.fixme';
71
- return '';
72
- }
73
- /**
74
- * Apply this function only to string literals (mostly titles here).
75
- * Objects and arrays are handled with JSON.strinigfy,
76
- * b/c object keys can't be in backtiks.
77
- * See: https://stackoverflow.com/questions/33194138/template-string-as-object-property-name
78
- */
79
- quoted(str) {
80
- return (0, _jsStringWrap.jsStringWrap)(str, {
81
- quotes: this.config.quotes
82
- });
83
- }
84
- }
85
- exports.Formatter = Formatter;
86
- function indent(value) {
87
- return value ? `${' '}${value}` : value;
88
- }