@zohodesk/testinglibrary 0.0.5 → 0.0.6

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 (111) hide show
  1. package/.babelrc +19 -0
  2. package/.eslintrc.js +27 -0
  3. package/.prettierrc +6 -0
  4. package/{changelog.md → Changelog.md} +38 -25
  5. package/README.md +17 -17
  6. package/bin/cli.js +2 -2
  7. package/bin/postinstall.js +1 -16
  8. package/build/bdd-framework/cli/commands/env.js +43 -0
  9. package/build/bdd-framework/cli/commands/export.js +48 -0
  10. package/build/bdd-framework/cli/commands/test.js +59 -0
  11. package/build/bdd-framework/cli/index.js +11 -0
  12. package/build/bdd-framework/cli/options.js +20 -0
  13. package/build/bdd-framework/cli/worker.js +13 -0
  14. package/build/bdd-framework/config/dir.js +27 -0
  15. package/build/bdd-framework/config/env.js +49 -0
  16. package/build/bdd-framework/config/index.js +91 -0
  17. package/build/bdd-framework/cucumber/buildStepDefinition.js +43 -0
  18. package/build/bdd-framework/cucumber/gherkin.d.js +5 -0
  19. package/build/bdd-framework/cucumber/gherkin.d.ts +45 -0
  20. package/build/bdd-framework/cucumber/loadConfig.js +17 -0
  21. package/build/bdd-framework/cucumber/loadFeatures.js +39 -0
  22. package/build/bdd-framework/cucumber/loadSnippetBuilder.js +20 -0
  23. package/build/bdd-framework/cucumber/loadSources.js +57 -0
  24. package/build/bdd-framework/cucumber/loadSteps.js +35 -0
  25. package/build/bdd-framework/decorators.js +22 -0
  26. package/build/bdd-framework/gen/formatter.js +88 -0
  27. package/build/bdd-framework/gen/i18n.js +35 -0
  28. package/build/bdd-framework/gen/index.js +160 -0
  29. package/build/bdd-framework/gen/poms.js +46 -0
  30. package/build/bdd-framework/gen/testFile.js +356 -0
  31. package/build/bdd-framework/gen/testNode.js +48 -0
  32. package/build/bdd-framework/gen/testPoms.js +123 -0
  33. package/build/bdd-framework/index.js +45 -0
  34. package/build/bdd-framework/playwright/fixtureParameterNames.js +77 -0
  35. package/build/bdd-framework/playwright/getLocationInFile.js +46 -0
  36. package/build/bdd-framework/playwright/loadConfig.js +42 -0
  37. package/build/bdd-framework/playwright/testTypeImpl.js +41 -0
  38. package/build/bdd-framework/playwright/transform.js +80 -0
  39. package/build/bdd-framework/playwright/types.js +5 -0
  40. package/build/bdd-framework/playwright/utils.js +34 -0
  41. package/build/bdd-framework/run/bddFixtures.js +108 -0
  42. package/build/bdd-framework/run/bddWorld.js +87 -0
  43. package/build/bdd-framework/snippets/index.js +131 -0
  44. package/build/bdd-framework/snippets/snippetSyntax.js +41 -0
  45. package/build/bdd-framework/snippets/snippetSyntaxDecorators.js +26 -0
  46. package/build/bdd-framework/snippets/snippetSyntaxTs.js +18 -0
  47. package/build/bdd-framework/stepDefinitions/createBdd.js +49 -0
  48. package/build/bdd-framework/stepDefinitions/createDecorators.js +109 -0
  49. package/build/bdd-framework/stepDefinitions/decorators/poms.js +50 -0
  50. package/build/bdd-framework/stepDefinitions/decorators/steps.js +94 -0
  51. package/build/bdd-framework/stepDefinitions/defineStep.js +61 -0
  52. package/build/bdd-framework/stepDefinitions/stepConfig.js +24 -0
  53. package/build/bdd-framework/utils/index.js +50 -0
  54. package/build/bdd-framework/utils/jsStringWrap.js +44 -0
  55. package/build/bdd-framework/utils/logger.js +29 -0
  56. package/build/core/jest/preprocessor/jsPreprocessor.js +13 -0
  57. package/{src → build}/core/jest/runner/jest-runner.js +46 -44
  58. package/build/core/jest/setup/index.js +9 -0
  59. package/build/core/playwright/codegen.js +55 -0
  60. package/build/core/playwright/custom-commands.js +8 -0
  61. package/build/core/playwright/env-initializer.js +21 -0
  62. package/{src → build}/core/playwright/index.js +112 -82
  63. package/build/core/playwright/readConfigFile.js +69 -0
  64. package/build/core/playwright/report-generator.js +41 -0
  65. package/build/core/playwright/setup/config-creator.js +117 -0
  66. package/build/core/playwright/test-runner.js +132 -0
  67. package/build/decorators.d.ts +1 -0
  68. package/build/decorators.js +16 -0
  69. package/build/index.d.ts +5 -0
  70. package/build/index.js +59 -0
  71. package/build/lib/cli.js +54 -0
  72. package/build/lib/post-install.js +17 -0
  73. package/build/lint/index.js +4 -0
  74. package/build/parser/parser.js +206 -0
  75. package/build/parser/sample.feature +34 -0
  76. package/build/parser/sample.spec.js +37 -0
  77. package/build/parser/verifier.js +130 -0
  78. package/build/setup-folder-structure/samples/auth-setup-sample.js +72 -0
  79. package/build/setup-folder-structure/samples/authUsers-sample.json +9 -0
  80. package/build/setup-folder-structure/samples/env-config-sample.json +21 -0
  81. package/build/setup-folder-structure/samples/git-ignore.sample.js +33 -0
  82. package/build/setup-folder-structure/samples/uat-config-sample.js +35 -0
  83. package/build/setup-folder-structure/setupProject.js +100 -0
  84. package/{src → build}/utils/cliArgsToObject.js +65 -63
  85. package/build/utils/fileUtils.js +53 -0
  86. package/build/utils/getFilePath.js +11 -0
  87. package/build/utils/logger.js +58 -0
  88. package/build/utils/rootPath.js +46 -0
  89. package/build/utils/stepDefinitionsFormatter.js +12 -0
  90. package/jest.config.js +63 -63
  91. package/npm-shrinkwrap.json +8790 -5772
  92. package/package.json +51 -30
  93. package/playwright.config.js +112 -112
  94. package/src/core/jest/preprocessor/jsPreprocessor.js +0 -9
  95. package/src/core/jest/setup/index.js +0 -165
  96. package/src/core/playwright/codegen.js +0 -60
  97. package/src/core/playwright/custom-commands.js +0 -3
  98. package/src/core/playwright/env-initializer.js +0 -24
  99. package/src/core/playwright/readConfigFile.js +0 -63
  100. package/src/core/playwright/report-generator.js +0 -45
  101. package/src/core/playwright/setup/config-creator.js +0 -77
  102. package/src/core/playwright/test-runner.js +0 -67
  103. package/src/index.js +0 -9
  104. package/src/lib/cli.js +0 -42
  105. package/src/setup-folder-structure/env-config-sample.json +0 -17
  106. package/src/setup-folder-structure/setupProject.js +0 -99
  107. package/src/setup-folder-structure/uat-config-sample.js +0 -22
  108. package/src/setup-folder-structure/user-example.json +0 -3
  109. package/src/utils/getFilePath.js +0 -9
  110. package/src/utils/logger.js +0 -28
  111. package/src/utils/rootPath.js +0 -51
@@ -0,0 +1,109 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.Fixture = Fixture;
7
+ exports.appendDecoratorSteps = appendDecoratorSteps;
8
+ exports.createStepDecorator = createStepDecorator;
9
+ exports.getPomNodeByFixtureName = getPomNodeByFixtureName;
10
+ var _bddFixtures = require("../run/bddFixtures");
11
+ var _defineStep = require("./defineStep");
12
+ var _buildStepDefinition = require("../cucumber/buildStepDefinition");
13
+ /* eslint-disable no-unused-vars */
14
+ /**
15
+ * Define steps via decorators.
16
+ */
17
+
18
+ const pomGraph = new Map();
19
+ const decoratedStepSymbol = Symbol('decoratedStep');
20
+ const decoratedSteps = new Set();
21
+ function Fixture(fixtureName) {
22
+ // context parameter is required for decorator by TS even though it's not used
23
+ return (Ctor, _context) => {
24
+ createPomNode(Ctor, fixtureName);
25
+ };
26
+ }
27
+ function createStepDecorator(keyword) {
28
+ return pattern => {
29
+ // context parameter is required for decorator by TS even though it's not used
30
+ return (method, _context) => {
31
+ method[decoratedStepSymbol] = {
32
+ keyword,
33
+ pattern,
34
+ fn: method,
35
+ hasCustomTest: true,
36
+ isDecorator: true
37
+ };
38
+ };
39
+ };
40
+ }
41
+ function appendDecoratorSteps(supportCodeLibrary) {
42
+ decoratedSteps.forEach(stepConfig => {
43
+ const {
44
+ keyword,
45
+ pattern,
46
+ fn
47
+ } = stepConfig;
48
+ stepConfig.fn = (fixturesArg, ...args) => {
49
+ const fixture = getFirstNonAutoInjectFixture(fixturesArg, stepConfig);
50
+ return fn.call(fixture, ...args);
51
+ };
52
+ const code = (0, _defineStep.buildCucumberStepFn)(stepConfig);
53
+ const stepDefinition = (0, _buildStepDefinition.buildStepDefinition)({
54
+ keyword,
55
+ pattern,
56
+ code,
57
+ line: 0,
58
+ // not used in playwright-bdd
59
+ options: {},
60
+ // not used in playwright-bdd
61
+ uri: '' // not used in playwright-bdd
62
+ }, supportCodeLibrary);
63
+ supportCodeLibrary.stepDefinitions.push(stepDefinition);
64
+ });
65
+ decoratedSteps.clear();
66
+ // todo: fill supportCodeLibrary.originalCoordinates as it is used in snippets?
67
+ }
68
+
69
+ function getPomNodeByFixtureName(fixtureName) {
70
+ for (const pomNode of pomGraph.values()) {
71
+ if (pomNode.fixtureName === fixtureName) return pomNode;
72
+ }
73
+ }
74
+ function createPomNode(Ctor, fixtureName) {
75
+ const pomNode = {
76
+ fixtureName,
77
+ children: new Set()
78
+ };
79
+ pomGraph.set(Ctor, pomNode);
80
+ getDecoratedSteps(Ctor).forEach(stepConfig => {
81
+ stepConfig.pomNode = pomNode;
82
+ decoratedSteps.add(stepConfig);
83
+ });
84
+ const parentCtor = Object.getPrototypeOf(Ctor);
85
+ if (!parentCtor) return;
86
+ const parentPomNode = pomGraph.get(parentCtor) || createPomNode(parentCtor, '');
87
+ parentPomNode === null || parentPomNode === void 0 || parentPomNode.children.add(pomNode);
88
+ return pomNode;
89
+ }
90
+ function getDecoratedSteps(Ctor) {
91
+ if (!(Ctor !== null && Ctor !== void 0 && Ctor.prototype)) return [];
92
+ const propertyDescriptors = Object.getOwnPropertyDescriptors(Ctor.prototype);
93
+ return Object.keys(propertyDescriptors)
94
+ // filter out getters / setters
95
+ .filter(methodName => typeof propertyDescriptors[methodName].value === 'function').map(methodName => {
96
+ return propertyDescriptors[methodName].value[decoratedStepSymbol];
97
+ }).filter(Boolean);
98
+ }
99
+ function getFirstNonAutoInjectFixture(fixturesArg, stepConfig) {
100
+ // there should be exatcly one suitable fixture in fixturesArg
101
+ const fixtureNames = Object.keys(fixturesArg).filter(fixtureName => !(0, _bddFixtures.isBddAutoInjectFixture)(fixtureName));
102
+ if (fixtureNames.length === 0) {
103
+ throw new Error(`No suitable fixtures found for decorator step "${stepConfig.pattern}"`);
104
+ }
105
+ if (fixtureNames.length > 1) {
106
+ throw new Error(`Several suitable fixtures found for decorator step "${stepConfig.pattern}"`);
107
+ }
108
+ return fixturesArg[fixtureNames[0]];
109
+ }
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.Fixture = Fixture;
7
+ exports.getPomNodeByFixtureName = getPomNodeByFixtureName;
8
+ var _steps = require("./steps");
9
+ /**
10
+ * POM classes marked with @Fixture
11
+ */
12
+
13
+ /**
14
+ * Graph of POM class inheritance.
15
+ * Allows to guess correct fixture by step text.
16
+ */
17
+ const pomGraph = new Map();
18
+ /**
19
+ * @Fixture decorator.
20
+ */
21
+ function Fixture(fixtureName) {
22
+ // context parameter is required for decorator by TS even though it's not used
23
+ // eslint-disable-next-line no-unused-vars
24
+ return (Ctor, _context) => {
25
+ createPomNode(Ctor, fixtureName);
26
+ };
27
+ }
28
+ function createPomNode(Ctor, fixtureName) {
29
+ const pomNode = {
30
+ fixtureName,
31
+ children: new Set()
32
+ };
33
+ pomGraph.set(Ctor, pomNode);
34
+ (0, _steps.linkStepsWithPomNode)(Ctor, pomNode);
35
+ linkParentWithPomNode(Ctor, pomNode);
36
+ return pomNode;
37
+ }
38
+ function linkParentWithPomNode(Ctor, pomNode) {
39
+ const parentCtor = Object.getPrototypeOf(Ctor);
40
+ if (!parentCtor) return;
41
+ // if parentCtor is not in pomGraph, add it as well
42
+ // Case: parent class is not marked with @Fixture, but has decorator steps (base class)
43
+ const parentPomNode = pomGraph.get(parentCtor) || createPomNode(parentCtor, '');
44
+ parentPomNode.children.add(pomNode);
45
+ }
46
+ function getPomNodeByFixtureName(fixtureName) {
47
+ for (const pomNode of pomGraph.values()) {
48
+ if (pomNode.fixtureName === fixtureName) return pomNode;
49
+ }
50
+ }
@@ -0,0 +1,94 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.appendDecoratorSteps = appendDecoratorSteps;
7
+ exports.createStepDecorator = createStepDecorator;
8
+ exports.linkStepsWithPomNode = linkStepsWithPomNode;
9
+ var _bddFixtures = require("../../run/bddFixtures");
10
+ var _buildStepDefinition = require("../../cucumber/buildStepDefinition");
11
+ var _defineStep = require("../defineStep");
12
+ /**
13
+ * Define steps via decorators.
14
+ */
15
+
16
+ // initially we sotre step data inside method,
17
+ // and then extract it in @Fixture decorator call
18
+ const decoratedStepSymbol = Symbol('decoratedStep');
19
+ // global list of all decorator steps
20
+ const decoratedSteps = new Set();
21
+ /**
22
+ * Creates @Given, @When, @Then decorators.
23
+ */
24
+ function createStepDecorator(keyword) {
25
+ return pattern => {
26
+ // context parameter is required for decorator by TS even though it's not used
27
+ // eslint-disable-next-line no-unused-vars
28
+ return (method, _context) => {
29
+ saveStepConfigToMethod(method, {
30
+ keyword,
31
+ pattern,
32
+ fn: method,
33
+ hasCustomTest: true
34
+ });
35
+ };
36
+ };
37
+ }
38
+ function linkStepsWithPomNode(Ctor, pomNode) {
39
+ if (!(Ctor !== null && Ctor !== void 0 && Ctor.prototype)) return;
40
+ const propertyDescriptors = Object.getOwnPropertyDescriptors(Ctor.prototype);
41
+ return Object.values(propertyDescriptors).forEach(descriptor => {
42
+ const stepConfig = getStepConfigFromMethod(descriptor);
43
+ if (!stepConfig) return;
44
+ stepConfig.pomNode = pomNode;
45
+ decoratedSteps.add(stepConfig);
46
+ });
47
+ }
48
+ /**
49
+ * Append decorator steps to Cucumber's supportCodeLibrary.
50
+ */
51
+ function appendDecoratorSteps(supportCodeLibrary) {
52
+ decoratedSteps.forEach(stepConfig => {
53
+ const {
54
+ keyword,
55
+ pattern,
56
+ fn
57
+ } = stepConfig;
58
+ stepConfig.fn = (fixturesArg, ...args) => {
59
+ const fixture = getFirstNonAutoInjectFixture(fixturesArg, stepConfig);
60
+ return fn.call(fixture, ...args);
61
+ };
62
+ const code = (0, _defineStep.buildCucumberStepCode)(stepConfig);
63
+ const stepDefinition = (0, _buildStepDefinition.buildStepDefinition)({
64
+ keyword,
65
+ pattern,
66
+ code,
67
+ line: 0,
68
+ options: {},
69
+ uri: '' // not used in playwright-bdd
70
+ }, supportCodeLibrary);
71
+ supportCodeLibrary.stepDefinitions.push(stepDefinition);
72
+ });
73
+ decoratedSteps.clear();
74
+ // todo: fill supportCodeLibrary.originalCoordinates as it is used in snippets?
75
+ }
76
+
77
+ function getFirstNonAutoInjectFixture(fixturesArg, stepConfig) {
78
+ // there should be exatcly one suitable fixture in fixturesArg
79
+ const fixtureNames = Object.keys(fixturesArg).filter(fixtureName => !(0, _bddFixtures.isBddAutoInjectFixture)(fixtureName));
80
+ if (fixtureNames.length === 0) {
81
+ throw new Error(`No suitable fixtures found for decorator step "${stepConfig.pattern}"`);
82
+ }
83
+ if (fixtureNames.length > 1) {
84
+ throw new Error(`Several suitable fixtures found for decorator step "${stepConfig.pattern}"`);
85
+ }
86
+ return fixturesArg[fixtureNames[0]];
87
+ }
88
+ function saveStepConfigToMethod(method, stepConfig) {
89
+ method[decoratedStepSymbol] = stepConfig;
90
+ }
91
+ function getStepConfigFromMethod(descriptor) {
92
+ // filter out getters / setters
93
+ return typeof descriptor.value === 'function' ? descriptor.value[decoratedStepSymbol] : undefined;
94
+ }
@@ -0,0 +1,61 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.buildCucumberStepCode = buildCucumberStepCode;
7
+ exports.defineStep = defineStep;
8
+ exports.getStepCode = getStepCode;
9
+ var _cucumber = require("@cucumber/cucumber");
10
+ var _utils = require("../utils");
11
+ /**
12
+ * Defines step by config.
13
+ * Calls cucumber's Given(), When(), Then() under the hood.
14
+ */
15
+ function defineStep(stepConfig) {
16
+ const {
17
+ keyword,
18
+ pattern
19
+ } = stepConfig;
20
+ const cucumberDefineStepFn = getCucumberDefineStepFn(keyword);
21
+ const code = buildCucumberStepCode(stepConfig);
22
+ try {
23
+ cucumberDefineStepFn(pattern, code);
24
+ } catch (e) {
25
+ // todo: detect that this is import from test file
26
+ // and skip/delay registering cucumber steps until cucumber is loaded
27
+ const isMissingCucumber = /Cucumber that isn't running/i.test(e.message);
28
+ if (isMissingCucumber) {
29
+ (0, _utils.exitWithMessage)(`Option "importTestFrom" should point to separate file without step definitions`, `(e.g. without calls of Given, When, Then)`);
30
+ } else {
31
+ throw e;
32
+ }
33
+ }
34
+ }
35
+ function buildCucumberStepCode(stepConfig) {
36
+ const code = function (...args) {
37
+ const fixturesArg = Object.assign({}, this.customFixtures, {
38
+ $testInfo: this.testInfo,
39
+ $test: this.test,
40
+ $tags: this.tags
41
+ });
42
+ return stepConfig.fn.call(this, fixturesArg, ...args);
43
+ };
44
+ code.stepConfig = stepConfig;
45
+ return code;
46
+ }
47
+ function getStepCode(stepDefinition) {
48
+ return stepDefinition.code;
49
+ }
50
+ function getCucumberDefineStepFn(keyword) {
51
+ switch (keyword) {
52
+ case 'Given':
53
+ return _cucumber.Given;
54
+ case 'When':
55
+ return _cucumber.When;
56
+ case 'Then':
57
+ return _cucumber.Then;
58
+ default:
59
+ return _cucumber.defineStep;
60
+ }
61
+ }
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.getStepConfig = getStepConfig;
7
+ exports.isDecorator = isDecorator;
8
+ exports.isPlaywrightStyle = isPlaywrightStyle;
9
+ /**
10
+ * Playwright-bdd's step config.
11
+ */
12
+ function getStepConfig(step) {
13
+ return step.code.stepConfig;
14
+ }
15
+ function isDecorator(stepConfig) {
16
+ return Boolean(stepConfig === null || stepConfig === void 0 ? void 0 : stepConfig.pomNode);
17
+ }
18
+ /**
19
+ * Cucumber-style steps don't have stepConfig
20
+ * b/c they created directly via cucumber's Given, When, Then.
21
+ */
22
+ function isPlaywrightStyle(stepConfig) {
23
+ return Boolean(stepConfig);
24
+ }
@@ -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.exitWithMessage = exitWithMessage;
8
+ exports.getPackageVersion = getPackageVersion;
9
+ exports.getSymbolByName = getSymbolByName;
10
+ exports.removeDuplicates = removeDuplicates;
11
+ exports.resolvePackageRoot = resolvePackageRoot;
12
+ exports.template = template;
13
+ var _fs = _interopRequireDefault(require("fs"));
14
+ var _path = _interopRequireDefault(require("path"));
15
+ var _logger = require("./logger");
16
+ function exitWithMessage(...messages) {
17
+ _logger.logger.error('ERROR:', ...messages.filter(Boolean));
18
+ process.exit(1);
19
+ }
20
+ // See: https://stackoverflow.com/questions/50453640/how-can-i-get-the-value-of-a-symbol-property
21
+ function getSymbolByName(target, name) {
22
+ const ownKeys = Reflect.ownKeys(target);
23
+ const symbol = ownKeys.find(key => key.toString() === `Symbol(${name})`);
24
+ if (!symbol) {
25
+ throw new Error(`Symbol "${name}" not found in target. ownKeys: ${ownKeys}`);
26
+ }
27
+ return symbol;
28
+ }
29
+ /**
30
+ * Inserts params into template.
31
+ * Params defined as <param>.
32
+ */
33
+ function template(t, params = {}) {
34
+ return t.replace(/<(.+?)>/g, (match, key) => {
35
+ return params[key] !== undefined ? String(params[key]) : match;
36
+ });
37
+ }
38
+ function removeDuplicates(arr) {
39
+ return [...new Set(arr)];
40
+ }
41
+ function resolvePackageRoot(packageName) {
42
+ const packageJsonPath = require.resolve(`${packageName}/package.json`);
43
+ return _path.default.dirname(packageJsonPath);
44
+ }
45
+ function getPackageVersion(packageName) {
46
+ const packageRoot = resolvePackageRoot(packageName);
47
+ const packageJsonPath = _path.default.join(packageRoot, 'package.json');
48
+ const packageJson = JSON.parse(_fs.default.readFileSync(packageJsonPath, 'utf8'));
49
+ return packageJson.version || '';
50
+ }
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.jsStringWrap = jsStringWrap;
7
+ /**
8
+ * Adopted version of https://github.com/joliss/js-string-escape
9
+ * - added support of backticks
10
+ * - added 'quotes' option to indicate which quotes to escape
11
+ * - wrap result string with provided quotes
12
+ *
13
+ * Considered alternative is https://github.com/mathiasbynens/jsesc,
14
+ * but it provides additional functionality and much slower
15
+ * See: https://github.com/mathiasbynens/jsesc/issues/16
16
+ */
17
+ function jsStringWrap(str, {
18
+ quotes = 'single'
19
+ } = {}) {
20
+ const wrapQuote = quotes === 'single' ? "'" : quotes === 'double' ? '"' : '`';
21
+ // eslint-disable-next-line complexity
22
+ const escapedStr = ('' + str).replace(/["'`\\\n\r\u2028\u2029]/g, character => {
23
+ // Escape all characters not included in SingleStringCharacters and
24
+ // DoubleStringCharacters on
25
+ // http://www.ecma-international.org/ecma-262/5.1/#sec-7.8.4
26
+ switch (character) {
27
+ case wrapQuote:
28
+ case '\\':
29
+ return '\\' + character;
30
+ // Four possible LineTerminator characters need to be escaped:
31
+ case '\n':
32
+ return '\\n';
33
+ case '\r':
34
+ return '\\r';
35
+ case '\u2028':
36
+ return '\\u2028';
37
+ case '\u2029':
38
+ return '\\u2029';
39
+ default:
40
+ return character;
41
+ }
42
+ });
43
+ return `${wrapQuote}${escapedStr}${wrapQuote}`;
44
+ }
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.logger = exports.Logger = void 0;
7
+ /**
8
+ * Simple logger
9
+ */
10
+ class Logger {
11
+ options;
12
+ constructor(options = {}) {
13
+ this.options = options;
14
+ }
15
+ log(...args) {
16
+ if (this.options.verbose) console.log(...args);
17
+ }
18
+ warn(...args) {
19
+ // using log() to output warnings to stdout, not stderr
20
+ console.log(...args);
21
+ }
22
+ error(...args) {
23
+ console.error(...args);
24
+ }
25
+ }
26
+ // default logger
27
+ exports.Logger = Logger;
28
+ const logger = new Logger();
29
+ exports.logger = logger;
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = void 0;
8
+ var _babelJest = _interopRequireDefault(require("babel-jest"));
9
+ var _default = _babelJest.default.createTransformer({
10
+ presets: [require.resolve('@babel/preset-env'), require.resolve('@babel/preset-react')],
11
+ plugins: [require.resolve('babel-plugin-transform-dynamic-import')]
12
+ });
13
+ exports.default = _default;
@@ -1,44 +1,46 @@
1
- // import { run } from 'jest';
2
-
3
- // function createJestRunner() {
4
- // let config = require('../configs/jest.config');
5
-
6
- // let argv = process.argv.slice(2);
7
-
8
- // argv.push('--config', JSON.stringify(config(folder)), '--no-cache');
9
- // run(argv);
10
- // }
11
-
12
-
13
- // export default createJestRunner;
14
-
15
- const { spawn } = require('child_process');
16
- const path = require('path');
17
- const { getExecutableBinaryPath } = require('../../../utils/rootPath');
18
-
19
- const jestPath = path.resolve(getExecutableBinaryPath('jest'));
20
-
21
- // Command and arguments for npx playwright test
22
- const command = jestPath;
23
- const args = ['--config', require.resolve('../../../../jest.config.js')];
24
-
25
-
26
- function createJestRunner() {
27
- // Spawn the child process
28
-
29
- const childProcess = spawn(command, args, { stdio: 'inherit' });
30
-
31
-
32
- // Handling the 'exit' event of the child process
33
- // childProcess.on('exit', (code, signal) => {
34
- // console.log(`Child process exited with code ${code} and signal ${signal}`);
35
- // });
36
-
37
- // // Handling any error that occurs while spawning the child process
38
- // childProcess.on('error', (err) => {
39
- // console.error(`Error while spawning child process: ${err.message}`);
40
- // });
41
- }
42
-
43
-
44
- module.exports = createJestRunner;
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = createJestRunner;
8
+ var _child_process = require("child_process");
9
+ var _path = _interopRequireDefault(require("path"));
10
+ var _rootPath = require("../../../utils/rootPath");
11
+ /* eslint-disable no-unused-vars */
12
+ // import { run } from 'jest';
13
+
14
+ // function createJestRunner() {
15
+ // let config from '../configs/jest.config');
16
+
17
+ // let argv = process.argv.slice(2);
18
+
19
+ // argv.push('--config', JSON.stringify(config(folder)), '--no-cache');
20
+ // run(argv);
21
+ // }
22
+
23
+ // export default createJestRunner;
24
+
25
+ const jestPath = _path.default.resolve((0, _rootPath.getExecutableBinaryPath)('jest'));
26
+
27
+ // Command and arguments for npx playwright test
28
+ const command = jestPath;
29
+ const args = ['--config', require.resolve('../../../../jest.config.js')];
30
+ function createJestRunner() {
31
+ // Spawn the child process
32
+
33
+ const childProcess = (0, _child_process.spawn)(command, args, {
34
+ stdio: 'inherit'
35
+ });
36
+
37
+ // Handling the 'exit' event of the child process
38
+ // childProcess.on('exit', (code, signal) => {
39
+ // console.log(`Child process exited with code ${code} and signal ${signal}`);
40
+ // });
41
+
42
+ // // Handling any error that occurs while spawning the child process
43
+ // childProcess.on('error', (err) => {
44
+ // console.error(`Error while spawning child process: ${err.message}`);
45
+ // });
46
+ }
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _testUtils = _interopRequireDefault(require("react-dom/test-utils"));
5
+ var _globals = require("@jest/globals");
6
+ var _react = _interopRequireDefault(require("react"));
7
+ var _propTypes = _interopRequireDefault(require("prop-types"));
8
+ var _reactDom = _interopRequireDefault(require("react-dom"));
9
+ require("@testing-library/jest-dom/extend-expect");
@@ -0,0 +1,55 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = generateCodegen;
8
+ var _child_process = require("child_process");
9
+ var _path = _interopRequireDefault(require("path"));
10
+ var _logger = require("../../utils/logger");
11
+ var _rootPath = require("../../utils/rootPath");
12
+ const userArgs = process.argv.slice(3);
13
+ const playwrightPath = _path.default.resolve((0, _rootPath.getExecutableBinaryPath)('playwright'));
14
+ const command = playwrightPath;
15
+ const args = ['codegen'].concat(userArgs);
16
+ function generateCodegen() {
17
+ const childProcess = (0, _child_process.spawn)(command, args, {
18
+ stdio: 'inherit'
19
+ });
20
+ childProcess.on('error', error => {
21
+ _logger.Logger.log(_logger.Logger.FAILURE_TYPE, error);
22
+ });
23
+ childProcess.on('exit', (code, signal) => {
24
+ _logger.Logger.log(_logger.Logger.FAILURE_TYPE, `Child Process Exited with Code ${code} and Signal ${signal}`);
25
+ process.exit();
26
+ });
27
+ process.on('exit', () => {
28
+ _logger.Logger.log(_logger.Logger.INFO_TYPE, 'Terminating Playwright Process...');
29
+ //childProcess.kill();
30
+ return;
31
+ });
32
+ process.on('SIGINT', () => {
33
+ _logger.Logger.log(_logger.Logger.INFO_TYPE, 'Cleaning up...');
34
+ //childProcess.kill();
35
+ process.exit();
36
+ });
37
+ }
38
+
39
+ // Another way to record. Below way will load the url in autheticated state if present
40
+ // function generateCodegen() {
41
+ // (async () => {
42
+ // // Make sure to run headed.
43
+ // const browser = await chromium.launch({ headless: false });
44
+
45
+ // // Setup context however you like.
46
+ // const context = await browser.newContext({ storageState: path.resolve(process.cwd(), 'uat', 'playwright/.auth/user.json') });
47
+ // await context.route('**/*', route => route.continue());
48
+
49
+ // // Pause the page, and start recording manually.
50
+ // const page = await context.newPage();
51
+ // console.log(userArgs.join(''));
52
+ // await page.goto(`https://${userArgs.join('')}`);
53
+ // await page.pause();
54
+ // })();
55
+ // }
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.CUSTOM_COMMANDS = void 0;
7
+ const CUSTOM_COMMANDS = ['mode', 'tags'];
8
+ exports.CUSTOM_COMMANDS = CUSTOM_COMMANDS;
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.initializeEnvConfig = initializeEnvConfig;
8
+ var _fs = require("fs");
9
+ var _path = _interopRequireDefault(require("path"));
10
+ function initializeEnvConfig(mode = 'dev') {
11
+ try {
12
+ const configFile = (0, _fs.readFileSync)(_path.default.resolve(process.cwd(), './uat/env-config.json'));
13
+ const configJSON = JSON.parse(configFile);
14
+ process.env.mode = mode;
15
+ for (const key in configJSON[mode]) {
16
+ process.env[key] = configJSON[mode][key];
17
+ }
18
+ } catch (err) {
19
+ throw new Error('Config File Not Exists. Please provide a config file to intiailize the environment variables');
20
+ }
21
+ }