@zohodesk/testinglibrary 2.9.1 → 3.0.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.
- package/.gitlab-ci.yml +16 -23
- package/README.md +32 -1
- package/build/core/playwright/constants/fileMutexConfig.js +11 -0
- package/build/core/playwright/fixtures.js +24 -0
- package/build/core/playwright/helpers/auth/checkAuthCookies.js +2 -8
- package/build/core/playwright/helpers/auth/loginSteps.js +25 -18
- package/build/core/playwright/helpers/checkAuthDirectory.js +17 -0
- package/build/core/playwright/helpers/fileMutex.js +58 -0
- package/build/core/playwright/index.js +10 -23
- package/build/core/playwright/setup/config-creator.js +3 -3
- package/build/core/playwright/setup/config-utils.js +8 -25
- package/build/core/playwright/test-runner.js +1 -1
- package/build/decorators.d.ts +1 -1
- package/build/decorators.js +1 -1
- package/build/setup-folder-structure/samples/actors-index.js +2 -0
- package/build/setup-folder-structure/samples/auth-setup-sample.js +14 -66
- package/build/setup-folder-structure/samples/editions-index.js +3 -0
- package/build/setup-folder-structure/samples/free-sample.json +25 -0
- package/build/setup-folder-structure/samples/settings.json +7 -0
- package/build/setup-folder-structure/setupProject.js +18 -5
- package/build/test/core/playwright/helpers/__tests__/fileMutex.test.js +94 -0
- package/nobdd/uat/conf/default/actors/index.js +1 -4
- package/nobdd/uat/conf/default/settings.json +1 -1
- package/nobdd/uat/conf/nobdd/uat.config.js +11 -4
- package/nobdd/uat/env-config.json +3 -3
- package/nobdd/uat/fixtures/setup.teardown.js +2 -1
- package/nobdd/uat/modules/nobdd/steps/VerifyNoBDD.feature.spec.js +3 -3
- package/nobdd/uat.config.js +8 -3
- package/package.json +8 -7
- package/build/bdd-framework/cli/commands/env.js +0 -42
- package/build/bdd-framework/cli/commands/export.js +0 -62
- package/build/bdd-framework/cli/commands/test.js +0 -64
- package/build/bdd-framework/cli/index.js +0 -11
- package/build/bdd-framework/cli/options.js +0 -19
- package/build/bdd-framework/cli/worker.js +0 -13
- package/build/bdd-framework/config/configDir.js +0 -35
- package/build/bdd-framework/config/enrichReporterData.js +0 -23
- package/build/bdd-framework/config/env.js +0 -50
- package/build/bdd-framework/config/index.js +0 -94
- package/build/bdd-framework/config/lang.js +0 -14
- package/build/bdd-framework/cucumber/buildStepDefinition.js +0 -43
- package/build/bdd-framework/cucumber/createTestStep.js +0 -43
- package/build/bdd-framework/cucumber/formatter/EventDataCollector.js +0 -126
- package/build/bdd-framework/cucumber/formatter/GherkinDocumentParser.js +0 -72
- package/build/bdd-framework/cucumber/formatter/PickleParser.js +0 -25
- package/build/bdd-framework/cucumber/formatter/durationHelpers.js +0 -13
- package/build/bdd-framework/cucumber/formatter/getColorFns.js +0 -57
- package/build/bdd-framework/cucumber/formatter/index.js +0 -16
- package/build/bdd-framework/cucumber/formatter/locationHelpers.js +0 -16
- package/build/bdd-framework/cucumber/loadConfig.js +0 -17
- package/build/bdd-framework/cucumber/loadFeatures.js +0 -70
- package/build/bdd-framework/cucumber/loadSnippetBuilder.js +0 -20
- package/build/bdd-framework/cucumber/loadSteps.js +0 -47
- package/build/bdd-framework/cucumber/resolveFeaturePaths.js +0 -62
- package/build/bdd-framework/cucumber/stepArguments.js +0 -21
- package/build/bdd-framework/cucumber/types.js +0 -5
- package/build/bdd-framework/cucumber/valueChecker.js +0 -23
- package/build/bdd-framework/decorators.js +0 -18
- package/build/bdd-framework/gen/fixtures.js +0 -48
- package/build/bdd-framework/gen/formatter.js +0 -167
- package/build/bdd-framework/gen/i18n.js +0 -39
- package/build/bdd-framework/gen/index.js +0 -197
- package/build/bdd-framework/gen/specialTags.js +0 -70
- package/build/bdd-framework/gen/testFile.js +0 -470
- package/build/bdd-framework/gen/testMeta.js +0 -60
- package/build/bdd-framework/gen/testNode.js +0 -35
- package/build/bdd-framework/gen/testPoms.js +0 -133
- package/build/bdd-framework/hooks/scenario.js +0 -130
- package/build/bdd-framework/hooks/worker.js +0 -89
- package/build/bdd-framework/index.js +0 -52
- package/build/bdd-framework/playwright/fixtureParameterNames.js +0 -93
- package/build/bdd-framework/playwright/getLocationInFile.js +0 -79
- package/build/bdd-framework/playwright/loadConfig.js +0 -42
- package/build/bdd-framework/playwright/loadUtils.js +0 -33
- package/build/bdd-framework/playwright/testTypeImpl.js +0 -79
- package/build/bdd-framework/playwright/transform.js +0 -88
- package/build/bdd-framework/playwright/types.js +0 -12
- package/build/bdd-framework/playwright/utils.js +0 -56
- package/build/bdd-framework/reporter/cucumber/base.js +0 -52
- package/build/bdd-framework/reporter/cucumber/custom.js +0 -73
- package/build/bdd-framework/reporter/cucumber/helper.js +0 -12
- package/build/bdd-framework/reporter/cucumber/html.js +0 -40
- package/build/bdd-framework/reporter/cucumber/index.js +0 -74
- package/build/bdd-framework/reporter/cucumber/json.js +0 -312
- package/build/bdd-framework/reporter/cucumber/junit.js +0 -205
- package/build/bdd-framework/reporter/cucumber/message.js +0 -20
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/AttachmentMapper.js +0 -82
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/Builder.js +0 -197
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/GherkinDocument.js +0 -43
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/GherkinDocumentClone.js +0 -52
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/GherkinDocuments.js +0 -105
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/Hook.js +0 -70
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/Meta.js +0 -45
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/Pickles.js +0 -27
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/Projects.js +0 -38
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/TestCase.js +0 -128
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/TestCaseRun.js +0 -154
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/TestCaseRunHooks.js +0 -123
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/TestStepAttachments.js +0 -67
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/TestStepRun.js +0 -114
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/index.js +0 -30
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/pwStepUtils.js +0 -70
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/timing.js +0 -35
- package/build/bdd-framework/reporter/cucumber/messagesBuilder/types.js +0 -5
- package/build/bdd-framework/run/StepInvoker.js +0 -69
- package/build/bdd-framework/run/bddData/index.js +0 -59
- package/build/bdd-framework/run/bddData/types.js +0 -5
- package/build/bdd-framework/run/bddFixtures.js +0 -192
- package/build/bdd-framework/run/bddWorld.js +0 -79
- package/build/bdd-framework/run/bddWorldInternal.js +0 -11
- package/build/bdd-framework/snippets/index.js +0 -132
- package/build/bdd-framework/snippets/snippetSyntax.js +0 -43
- package/build/bdd-framework/snippets/snippetSyntaxDecorators.js +0 -26
- package/build/bdd-framework/snippets/snippetSyntaxTs.js +0 -18
- package/build/bdd-framework/stepDefinitions/createBdd.js +0 -66
- package/build/bdd-framework/stepDefinitions/decorators/class.js +0 -68
- package/build/bdd-framework/stepDefinitions/decorators/steps.js +0 -99
- package/build/bdd-framework/stepDefinitions/defineStep.js +0 -62
- package/build/bdd-framework/stepDefinitions/stepConfig.js +0 -24
- package/build/bdd-framework/steps/createBdd.js +0 -78
- package/build/bdd-framework/steps/decorators/class.js +0 -68
- package/build/bdd-framework/steps/decorators/steps.js +0 -98
- package/build/bdd-framework/steps/defineStep.js +0 -62
- package/build/bdd-framework/steps/stepConfig.js +0 -24
- package/build/bdd-framework/utils/AutofillMap.js +0 -20
- package/build/bdd-framework/utils/exit.js +0 -62
- package/build/bdd-framework/utils/index.js +0 -93
- package/build/bdd-framework/utils/jsStringWrap.js +0 -44
- package/build/bdd-framework/utils/logger.js +0 -30
- package/build/bdd-framework/utils/stripAnsiEscapes.js +0 -20
- package/build/setup-folder-structure/samples/authUsers-sample.json +0 -9
- package/build/setup-folder-structure/samples/env-config-sample.json +0 -21
- package/nobdd/uat/conf/default/actors/beta/custom-module.json +0 -24
- package/nobdd/uat/conf/default/actors/beta/index.js +0 -6
- package/nobdd/uat/conf/default/actors/beta/parent-child.json +0 -24
- package/npm-shrinkwrap.json +0 -6475
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.isTestContainsSubtest = isTestContainsSubtest;
|
|
7
|
-
exports.runStepWithCustomLocation = runStepWithCustomLocation;
|
|
8
|
-
var _test = require("@playwright/test");
|
|
9
|
-
var _utils = require("../utils");
|
|
10
|
-
var _utils2 = require("./utils");
|
|
11
|
-
/**
|
|
12
|
-
* Helpers to deal with Playwright test internal stuff.
|
|
13
|
-
* See: https://github.com/microsoft/playwright/blob/main/packages/playwright-test/src/common/testType.ts
|
|
14
|
-
*/
|
|
15
|
-
|
|
16
|
-
const testTypeSymbol = (0, _utils.getSymbolByName)(_test.test, 'testType');
|
|
17
|
-
/**
|
|
18
|
-
* Returns test fixtures using Symbol.
|
|
19
|
-
*/
|
|
20
|
-
function getTestFixtures(test) {
|
|
21
|
-
return getTestImpl(test).fixtures;
|
|
22
|
-
}
|
|
23
|
-
function getTestImpl(test) {
|
|
24
|
-
return test[testTypeSymbol];
|
|
25
|
-
}
|
|
26
|
-
/**
|
|
27
|
-
* Run step with location pointing to Given, When, Then call.
|
|
28
|
-
*/
|
|
29
|
-
// eslint-disable-next-line max-params
|
|
30
|
-
async function runStepWithCustomLocation(test, stepText, location, body) {
|
|
31
|
-
// Since PW 1.43 testInfo._runAsStep was replaced with a more complex logic.
|
|
32
|
-
// To run step with a custom location, we hijack testInfo._addStep()
|
|
33
|
-
// so that it appends location for the bdd step calls.
|
|
34
|
-
// Finally we call test.step(), that internally invokes testInfo._addStep().
|
|
35
|
-
// See: https://github.com/microsoft/playwright/issues/30160
|
|
36
|
-
// See: https://github.com/microsoft/playwright/blob/release-1.43/packages/playwright/src/common/testType.ts#L262
|
|
37
|
-
// See: https://github.com/microsoft/playwright/blob/release-1.43/packages/playwright/src/worker/testInfo.ts#L247
|
|
38
|
-
if (_utils2.playwrightVersion >= '1.39.0') {
|
|
39
|
-
const testInfo = test.info();
|
|
40
|
-
// here we rely on that testInfo._addStep is called synchronously in test.step()
|
|
41
|
-
const origAddStep = testInfo._addStep;
|
|
42
|
-
testInfo._addStep = function (data) {
|
|
43
|
-
data.location = location;
|
|
44
|
-
testInfo._addStep = origAddStep;
|
|
45
|
-
return origAddStep.call(this, data);
|
|
46
|
-
};
|
|
47
|
-
return test.step(stepText, body);
|
|
48
|
-
} else {
|
|
49
|
-
const testInfo = test.info();
|
|
50
|
-
return testInfo._runAsStep({
|
|
51
|
-
category: 'test.step',
|
|
52
|
-
title: stepText,
|
|
53
|
-
location
|
|
54
|
-
}, async () => {
|
|
55
|
-
return await body();
|
|
56
|
-
});
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
/**
|
|
60
|
-
* Returns true if test contains all fixtures of subtest.
|
|
61
|
-
* - test was extended from subtest
|
|
62
|
-
* - test is a result of mergeTests(subtest, ...)
|
|
63
|
-
*/
|
|
64
|
-
function isTestContainsSubtest(test, subtest) {
|
|
65
|
-
if (test === subtest) {
|
|
66
|
-
return true;
|
|
67
|
-
}
|
|
68
|
-
const testFixtures = new Set(getTestFixtures(test).map(f => locationToString(f.location)));
|
|
69
|
-
return getTestFixtures(subtest).every(f => {
|
|
70
|
-
return testFixtures.has(locationToString(f.location));
|
|
71
|
-
});
|
|
72
|
-
}
|
|
73
|
-
function locationToString({
|
|
74
|
-
file,
|
|
75
|
-
line,
|
|
76
|
-
column
|
|
77
|
-
}) {
|
|
78
|
-
return `${file}:${line}:${column}`;
|
|
79
|
-
}
|
|
@@ -1,88 +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.installTransform = installTransform;
|
|
8
|
-
exports.requireTransform = requireTransform;
|
|
9
|
-
var _module = _interopRequireDefault(require("module"));
|
|
10
|
-
var _fs = _interopRequireDefault(require("fs"));
|
|
11
|
-
var _path = _interopRequireDefault(require("path"));
|
|
12
|
-
var _utils = require("./utils");
|
|
13
|
-
/* eslint-disable max-params */
|
|
14
|
-
/**
|
|
15
|
-
* Installs require hook to transform ts.
|
|
16
|
-
* Extracted from playwright.
|
|
17
|
-
* See: https://github.com/microsoft/playwright/blob/main/packages/playwright-test/src/transform/transform.ts
|
|
18
|
-
*/
|
|
19
|
-
function installTransform() {
|
|
20
|
-
const {
|
|
21
|
-
pirates
|
|
22
|
-
} = (0, _utils.requirePlaywrightModule)('lib/utilsBundle.js');
|
|
23
|
-
const {
|
|
24
|
-
resolveHook,
|
|
25
|
-
shouldTransform,
|
|
26
|
-
transformHook
|
|
27
|
-
} = requireTransform();
|
|
28
|
-
let reverted = false;
|
|
29
|
-
const originalResolveFilename = _module.default._resolveFilename;
|
|
30
|
-
function resolveFilename(specifier, parent, ...rest) {
|
|
31
|
-
if (!reverted && parent) {
|
|
32
|
-
const resolved = resolveHook(parent.filename, specifier);
|
|
33
|
-
if (resolved !== undefined) {
|
|
34
|
-
specifier = resolved;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
return originalResolveFilename.call(this, specifier, parent, ...rest);
|
|
38
|
-
}
|
|
39
|
-
_module.default._resolveFilename = resolveFilename;
|
|
40
|
-
const revertPirates = pirates.addHook((code, filename) => {
|
|
41
|
-
if (!shouldTransform(filename)) {
|
|
42
|
-
return code;
|
|
43
|
-
}
|
|
44
|
-
// Since PW 1.42 transformHook returns { code, serializedCache } instead of code string
|
|
45
|
-
// See: https://github.com/microsoft/playwright/commit/f605a5009b3c75746120a6ec6d940f62624af5ec#diff-0f8a2f313f1572108f59a6e84663858ebb4fc455163410526b56878794001103
|
|
46
|
-
// See: https://github.com/vitalets/playwright-bdd/issues/96
|
|
47
|
-
const res = transformHook(code, filename);
|
|
48
|
-
return typeof res === 'string' ? res : res.code;
|
|
49
|
-
}, {
|
|
50
|
-
exts: ['.ts', '.tsx', '.js', '.jsx', '.mjs']
|
|
51
|
-
});
|
|
52
|
-
return () => {
|
|
53
|
-
reverted = true;
|
|
54
|
-
_module.default._resolveFilename = originalResolveFilename;
|
|
55
|
-
revertPirates();
|
|
56
|
-
};
|
|
57
|
-
}
|
|
58
|
-
function requireTransform() {
|
|
59
|
-
const transformPathSince1_35 = (0, _utils.getPlaywrightModulePath)('lib/transform/transform.js');
|
|
60
|
-
if (_fs.default.existsSync(transformPathSince1_35)) {
|
|
61
|
-
const {
|
|
62
|
-
resolveHook,
|
|
63
|
-
shouldTransform,
|
|
64
|
-
transformHook,
|
|
65
|
-
requireOrImport
|
|
66
|
-
} = (0, _utils.requirePlaywrightModule)(transformPathSince1_35);
|
|
67
|
-
return {
|
|
68
|
-
resolveHook,
|
|
69
|
-
shouldTransform,
|
|
70
|
-
transformHook,
|
|
71
|
-
requireOrImport
|
|
72
|
-
};
|
|
73
|
-
} else {
|
|
74
|
-
const {
|
|
75
|
-
resolveHook,
|
|
76
|
-
transformHook,
|
|
77
|
-
requireOrImport
|
|
78
|
-
} = (0, _utils.requirePlaywrightModule)('lib/common/transform.js');
|
|
79
|
-
// see: https://github.com/microsoft/playwright/blob/b4ffb848de1b00e9a0abad6dacdccce60cce9bed/packages/playwright-test/src/reporters/base.ts#L524
|
|
80
|
-
const shouldTransform = file => !file.includes(`${_path.default.sep}node_modules${_path.default.sep}`);
|
|
81
|
-
return {
|
|
82
|
-
resolveHook,
|
|
83
|
-
shouldTransform,
|
|
84
|
-
transformHook,
|
|
85
|
-
requireOrImport
|
|
86
|
-
};
|
|
87
|
-
}
|
|
88
|
-
}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
Object.defineProperty(exports, "PlaywrightLocation", {
|
|
7
|
-
enumerable: true,
|
|
8
|
-
get: function () {
|
|
9
|
-
return _reporter.Location;
|
|
10
|
-
}
|
|
11
|
-
});
|
|
12
|
-
var _reporter = require("@playwright/test/reporter");
|
|
@@ -1,56 +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.getPlaywrightModulePath = getPlaywrightModulePath;
|
|
8
|
-
exports.playwrightVersion = void 0;
|
|
9
|
-
exports.requirePlaywrightModule = requirePlaywrightModule;
|
|
10
|
-
exports.updateAnnotation = updateAnnotation;
|
|
11
|
-
var _fs = _interopRequireDefault(require("fs"));
|
|
12
|
-
var _path = _interopRequireDefault(require("path"));
|
|
13
|
-
var _utils = require("../utils");
|
|
14
|
-
// cache playwright root
|
|
15
|
-
let playwrightRoot = '';
|
|
16
|
-
const playwrightVersion = exports.playwrightVersion = (0, _utils.getPackageVersion)('@playwright/test');
|
|
17
|
-
/**
|
|
18
|
-
* Requires Playwright's internal module that is not exported via package.exports.
|
|
19
|
-
*/
|
|
20
|
-
function requirePlaywrightModule(modulePath) {
|
|
21
|
-
const absPath = _path.default.isAbsolute(modulePath) ? modulePath : getPlaywrightModulePath(modulePath);
|
|
22
|
-
return require(absPath);
|
|
23
|
-
}
|
|
24
|
-
function getPlaywrightModulePath(relativePath) {
|
|
25
|
-
return _path.default.join(getPlaywrightRoot(), relativePath);
|
|
26
|
-
}
|
|
27
|
-
function getPlaywrightRoot() {
|
|
28
|
-
if (!playwrightRoot) {
|
|
29
|
-
// Since 1.38 all modules moved from @playwright/test to playwright.
|
|
30
|
-
// Here we check existance of 'lib' dir instead of checking version.
|
|
31
|
-
// See: https://github.com/microsoft/playwright/pull/26946
|
|
32
|
-
const playwrightTestRoot = (0, _utils.resolvePackageRoot)('@playwright/test');
|
|
33
|
-
const libDir = _path.default.join(playwrightTestRoot, 'lib');
|
|
34
|
-
playwrightRoot = _fs.default.existsSync(libDir) ? playwrightTestRoot : (0, _utils.resolvePackageRoot)('playwright');
|
|
35
|
-
}
|
|
36
|
-
return playwrightRoot;
|
|
37
|
-
}
|
|
38
|
-
/**
|
|
39
|
-
* Create or update annotation with provided type.
|
|
40
|
-
*/
|
|
41
|
-
function updateAnnotation(testInfo, annotation, {
|
|
42
|
-
create = false
|
|
43
|
-
} = {}) {
|
|
44
|
-
const {
|
|
45
|
-
annotations
|
|
46
|
-
} = testInfo;
|
|
47
|
-
const index = annotations.findIndex(a => a.type === annotation.type);
|
|
48
|
-
if (index === -1 && !create) {
|
|
49
|
-
throw new Error(`Annotation "${annotation.type}" is not found.`);
|
|
50
|
-
}
|
|
51
|
-
if (index === -1) {
|
|
52
|
-
annotations.push(annotation);
|
|
53
|
-
} else {
|
|
54
|
-
annotations[index] = annotation;
|
|
55
|
-
}
|
|
56
|
-
}
|
|
@@ -1,52 +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.default = void 0;
|
|
8
|
-
var _path = _interopRequireDefault(require("path"));
|
|
9
|
-
var _fs = _interopRequireDefault(require("fs"));
|
|
10
|
-
var _promises = require("node:stream/promises");
|
|
11
|
-
/**
|
|
12
|
-
* Base reporter for Cucumber reporters.
|
|
13
|
-
* Reference: https://github.com/cucumber/cucumber-js/blob/main/src/formatter/index.ts
|
|
14
|
-
*/
|
|
15
|
-
|
|
16
|
-
class BaseReporter {
|
|
17
|
-
internalOptions;
|
|
18
|
-
outputStream = process.stdout;
|
|
19
|
-
constructor(internalOptions) {
|
|
20
|
-
this.internalOptions = internalOptions;
|
|
21
|
-
}
|
|
22
|
-
get eventBroadcaster() {
|
|
23
|
-
return this.internalOptions.eventBroadcaster;
|
|
24
|
-
}
|
|
25
|
-
get eventDataCollector() {
|
|
26
|
-
return this.internalOptions.eventDataCollector;
|
|
27
|
-
}
|
|
28
|
-
printsToStdio() {
|
|
29
|
-
return isStdout(this.outputStream);
|
|
30
|
-
}
|
|
31
|
-
async init() {}
|
|
32
|
-
async finished() {
|
|
33
|
-
if (!isStdout(this.outputStream)) {
|
|
34
|
-
this.outputStream.end();
|
|
35
|
-
await (0, _promises.finished)(this.outputStream);
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
setOutputStream(outputFile) {
|
|
39
|
-
if (!outputFile) {
|
|
40
|
-
return;
|
|
41
|
-
}
|
|
42
|
-
const absolutePath = _path.default.resolve(this.internalOptions.cwd, outputFile);
|
|
43
|
-
_fs.default.mkdirSync(_path.default.dirname(absolutePath), {
|
|
44
|
-
recursive: true
|
|
45
|
-
});
|
|
46
|
-
this.outputStream = _fs.default.createWriteStream(absolutePath);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
exports.default = BaseReporter;
|
|
50
|
-
function isStdout(stream) {
|
|
51
|
-
return stream === process.stdout;
|
|
52
|
-
}
|
|
@@ -1,73 +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.default = void 0;
|
|
8
|
-
var _base = _interopRequireDefault(require("./base"));
|
|
9
|
-
var _loadUtils = require("../../playwright/loadUtils");
|
|
10
|
-
var _getColorFns = _interopRequireDefault(require("../../cucumber/formatter/getColorFns"));
|
|
11
|
-
/**
|
|
12
|
-
* Custom Cucumber reporter.
|
|
13
|
-
* See: https://github.com/cucumber/cucumber-js/blob/main/docs/custom_formatters.md
|
|
14
|
-
*/
|
|
15
|
-
|
|
16
|
-
class CustomReporter extends _base.default {
|
|
17
|
-
reporterPathOrModule;
|
|
18
|
-
userOptions;
|
|
19
|
-
formatter;
|
|
20
|
-
constructor(internalOptions, reporterPathOrModule, userOptions = {}) {
|
|
21
|
-
super(internalOptions);
|
|
22
|
-
this.reporterPathOrModule = reporterPathOrModule;
|
|
23
|
-
this.userOptions = userOptions;
|
|
24
|
-
this.setOutputStream(this.userOptions.outputFile);
|
|
25
|
-
}
|
|
26
|
-
printsToStdio() {
|
|
27
|
-
// currently always return true, b/c loading of custom reporter is async,
|
|
28
|
-
// but printsToStdio() is called synchronously at the beginning.
|
|
29
|
-
return true;
|
|
30
|
-
}
|
|
31
|
-
async init() {
|
|
32
|
-
const formatterOptions = this.buildFormatterOptions();
|
|
33
|
-
const FormatterConstructor = await this.loadFormatterFromFile();
|
|
34
|
-
this.formatter = new FormatterConstructor(formatterOptions);
|
|
35
|
-
}
|
|
36
|
-
async finished() {
|
|
37
|
-
var _this$formatter;
|
|
38
|
-
await ((_this$formatter = this.formatter) === null || _this$formatter === void 0 ? void 0 : _this$formatter.finished());
|
|
39
|
-
await super.finished();
|
|
40
|
-
}
|
|
41
|
-
async loadFormatterFromFile() {
|
|
42
|
-
// see: https://github.com/microsoft/playwright/blob/main/packages/playwright/src/common/config.ts#L225
|
|
43
|
-
const reporterPath = require.resolve(this.reporterPathOrModule, {
|
|
44
|
-
paths: [this.internalOptions.cwd]
|
|
45
|
-
});
|
|
46
|
-
return (0, _loadUtils.requireOrImportDefaultFunction)(reporterPath, true);
|
|
47
|
-
}
|
|
48
|
-
buildFormatterOptions() {
|
|
49
|
-
const colorFns = (0, _getColorFns.default)(this.outputStream, process.env, this.userOptions.colorsEnabled);
|
|
50
|
-
return {
|
|
51
|
-
cwd: this.internalOptions.cwd,
|
|
52
|
-
eventBroadcaster: this.eventBroadcaster,
|
|
53
|
-
eventDataCollector: this.eventDataCollector,
|
|
54
|
-
parsedArgvOptions: this.userOptions,
|
|
55
|
-
colorFns,
|
|
56
|
-
stream: this.outputStream,
|
|
57
|
-
log: this.outputStream.write.bind(this.outputStream),
|
|
58
|
-
cleanup: async () => {},
|
|
59
|
-
snippetBuilder: null,
|
|
60
|
-
supportCodeLibrary: {
|
|
61
|
-
World: {}
|
|
62
|
-
}
|
|
63
|
-
};
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
// const fakeSuportCodeLibrary = {
|
|
67
|
-
// parameterTypeRegistry: ParameterTypeRegistry;
|
|
68
|
-
// stepDefinitions: StepDefinition[];
|
|
69
|
-
// // eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
70
|
-
// World: any;
|
|
71
|
-
// originalCoordinates: ISupportCodeCoordinates;
|
|
72
|
-
// }
|
|
73
|
-
exports.default = CustomReporter;
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.cucumberReporter = cucumberReporter;
|
|
7
|
-
function cucumberReporter(type, userOptions) {
|
|
8
|
-
return ['../../../bdd-framework/reporter/cucumber/index.js', {
|
|
9
|
-
$type: type,
|
|
10
|
-
...(userOptions || {})
|
|
11
|
-
}];
|
|
12
|
-
}
|
|
@@ -1,40 +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.default = void 0;
|
|
8
|
-
var _promises = require("node:stream/promises");
|
|
9
|
-
var _htmlFormatter = _interopRequireDefault(require("@cucumber/html-formatter"));
|
|
10
|
-
var _utils = require("../../utils");
|
|
11
|
-
var _path = _interopRequireDefault(require("path"));
|
|
12
|
-
var _base = _interopRequireDefault(require("./base"));
|
|
13
|
-
/**
|
|
14
|
-
* Cucumber html reporter.
|
|
15
|
-
* Based on: https://github.com/cucumber/cucumber-js/blob/main/src/formatter/html_formatter.ts
|
|
16
|
-
* See: https://github.com/cucumber/html-formatter
|
|
17
|
-
* See: https://github.com/cucumber/react-components
|
|
18
|
-
*/
|
|
19
|
-
|
|
20
|
-
class HtmlReporter extends _base.default {
|
|
21
|
-
userOptions;
|
|
22
|
-
htmlStream;
|
|
23
|
-
constructor(internalOptions, userOptions = {}) {
|
|
24
|
-
super(internalOptions);
|
|
25
|
-
this.userOptions = userOptions;
|
|
26
|
-
this.setOutputStream(this.userOptions.outputFile);
|
|
27
|
-
const packageRoot = (0, _utils.resolvePackageRoot)('@cucumber/html-formatter');
|
|
28
|
-
this.htmlStream = new _htmlFormatter.default(_path.default.join(packageRoot, 'dist/main.css'), _path.default.join(packageRoot, 'dist/main.js'));
|
|
29
|
-
this.eventBroadcaster.on('envelope', envelope => {
|
|
30
|
-
this.htmlStream.write(envelope);
|
|
31
|
-
});
|
|
32
|
-
this.htmlStream.pipe(this.outputStream);
|
|
33
|
-
}
|
|
34
|
-
async finished() {
|
|
35
|
-
this.htmlStream.end();
|
|
36
|
-
await (0, _promises.finished)(this.htmlStream);
|
|
37
|
-
await super.finished();
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
exports.default = HtmlReporter;
|
|
@@ -1,74 +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.default = void 0;
|
|
8
|
-
var _events = _interopRequireDefault(require("events"));
|
|
9
|
-
var _messagesBuilder = require("./messagesBuilder");
|
|
10
|
-
var _configDir = require("../../config/configDir");
|
|
11
|
-
var _enrichReporterData = require("../../config/enrichReporterData");
|
|
12
|
-
var _message = _interopRequireDefault(require("./message"));
|
|
13
|
-
var _html = _interopRequireDefault(require("./html"));
|
|
14
|
-
var _junit = _interopRequireDefault(require("./junit"));
|
|
15
|
-
var _json = _interopRequireDefault(require("./json"));
|
|
16
|
-
var _custom = _interopRequireDefault(require("./custom"));
|
|
17
|
-
/**
|
|
18
|
-
* Playwright reporter that generates different Cucumber reports.
|
|
19
|
-
*/
|
|
20
|
-
|
|
21
|
-
const builtinReporters = {
|
|
22
|
-
html: _html.default,
|
|
23
|
-
message: _message.default,
|
|
24
|
-
junit: _junit.default,
|
|
25
|
-
json: _json.default
|
|
26
|
-
};
|
|
27
|
-
class CucumberReporterAdapter {
|
|
28
|
-
messagesBuilderRef;
|
|
29
|
-
type;
|
|
30
|
-
userOptions;
|
|
31
|
-
reporter;
|
|
32
|
-
constructor(fullOptions) {
|
|
33
|
-
const {
|
|
34
|
-
$type,
|
|
35
|
-
...userOptions
|
|
36
|
-
} = fullOptions;
|
|
37
|
-
this.type = $type;
|
|
38
|
-
this.userOptions = userOptions;
|
|
39
|
-
(0, _enrichReporterData.enableEnrichReporterData)();
|
|
40
|
-
this.messagesBuilderRef = (0, _messagesBuilder.getMessagesBuilderRef)();
|
|
41
|
-
this.reporter = this.createCucumberReporter();
|
|
42
|
-
}
|
|
43
|
-
printsToStdio() {
|
|
44
|
-
return this.reporter.printsToStdio();
|
|
45
|
-
}
|
|
46
|
-
onTestEnd(test, result) {
|
|
47
|
-
this.messagesBuilderRef.onTestEnd(test, result);
|
|
48
|
-
}
|
|
49
|
-
async onEnd(result) {
|
|
50
|
-
this.messagesBuilderRef.onEnd(result);
|
|
51
|
-
await this.reporter.init();
|
|
52
|
-
await this.messagesBuilderRef.builder.buildMessages();
|
|
53
|
-
this.messagesBuilderRef.builder.emitMessages(this.reporter.eventBroadcaster);
|
|
54
|
-
await this.reporter.finished();
|
|
55
|
-
}
|
|
56
|
-
createCucumberReporter() {
|
|
57
|
-
const internalOptions = {
|
|
58
|
-
cwd: (0, _configDir.getPlaywrightConfigDir)(),
|
|
59
|
-
eventBroadcaster: new _events.default(),
|
|
60
|
-
eventDataCollector: this.messagesBuilderRef.builder.eventDataCollector
|
|
61
|
-
};
|
|
62
|
-
if (isBuiltInReporter(this.type)) {
|
|
63
|
-
const BuiltInReporter = builtinReporters[this.type];
|
|
64
|
-
return new BuiltInReporter(internalOptions, this.userOptions);
|
|
65
|
-
} else {
|
|
66
|
-
const reporterPath = this.type;
|
|
67
|
-
return new _custom.default(internalOptions, reporterPath, this.userOptions);
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
exports.default = CucumberReporterAdapter;
|
|
72
|
-
function isBuiltInReporter(type) {
|
|
73
|
-
return type in builtinReporters;
|
|
74
|
-
}
|