You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
134 lines
19 KiB
134 lines
19 KiB
"use strict";
|
|
var playwrightSuitNode_1 = require("./playwrightSuitNode");
|
|
var playwrightTestNode_1 = require("./playwrightTestNode");
|
|
var playwrightTestStructure_1 = require("./playwrightTestStructure");
|
|
var testNodeStatus_1 = require("../core/testNodeStatus");
|
|
var ansiRegexPattern = [
|
|
'[\\u001B\\u009B][[\\]()#;?]*(?:(?:(?:(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]+)*|[a-zA-Z\\d]+(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]*)*)?\\u0007)',
|
|
'(?:(?:\\d{1,4}(?:;\\d{0,4})*)?[\\dA-PR-TZcf-ntqry=><~]))'
|
|
].join('|');
|
|
var ansiRegex = new RegExp(ansiRegexPattern, 'g');
|
|
var PlaywrightJBReporter = /** @class */ (function () {
|
|
function PlaywrightJBReporter() {
|
|
this.testStructure = new playwrightTestStructure_1.default();
|
|
this.globalErrors = [];
|
|
}
|
|
PlaywrightJBReporter.prototype.printsToStdio = function () {
|
|
return true;
|
|
};
|
|
PlaywrightJBReporter.prototype.onStdErr = function (chunk, test, result) {
|
|
if (test == null) {
|
|
return process.stderr.write(chunk);
|
|
}
|
|
if (chunk instanceof Buffer) {
|
|
chunk = chunk.toString();
|
|
}
|
|
this.testStructure.testStdErr(new playwrightTestNode_1.default(test), chunk);
|
|
};
|
|
PlaywrightJBReporter.prototype.onStdOut = function (chunk, test, result) {
|
|
if (test == null) {
|
|
return process.stdout.write(chunk);
|
|
}
|
|
if (chunk instanceof Buffer) {
|
|
chunk = chunk.toString();
|
|
}
|
|
this.testStructure.testStdOut(new playwrightTestNode_1.default(test), chunk);
|
|
};
|
|
PlaywrightJBReporter.prototype.onBegin = function (config, suite) {
|
|
this.testStructure.startTesting(new playwrightSuitNode_1.default(suite));
|
|
// root
|
|
this.testStructure.startSuite(new playwrightSuitNode_1.default(suite));
|
|
};
|
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
PlaywrightJBReporter.prototype.onTestBegin = function (test, result) {
|
|
var _this = this;
|
|
var suite = new playwrightSuitNode_1.default(test.parent);
|
|
var suitesToStart = [];
|
|
while (suite !== undefined && suite.status === testNodeStatus_1.default.NotStarted) {
|
|
suitesToStart.push(suite);
|
|
if (suite.nativeSuite.parent === undefined)
|
|
suite = undefined;
|
|
else
|
|
suite = new playwrightSuitNode_1.default(suite.nativeSuite.parent);
|
|
}
|
|
suitesToStart.reverse().forEach(function (suite) {
|
|
_this.testStructure.startSuite(suite);
|
|
});
|
|
this.testStructure.startTest(new playwrightTestNode_1.default(test));
|
|
if (test.expectedStatus == 'skipped') {
|
|
this.testStructure.ignoreTest(new playwrightTestNode_1.default(test));
|
|
}
|
|
};
|
|
PlaywrightJBReporter.prototype.onStepBegin = function (test, result, step) {
|
|
this.testStructure.startStep(step);
|
|
};
|
|
PlaywrightJBReporter.prototype.onStepEnd = function (test, result, step) {
|
|
this.testStructure.finishStep(step);
|
|
};
|
|
PlaywrightJBReporter.prototype.onTestEnd = function (test, result) {
|
|
// If the test status is interrupted, don't have to finish test in structure, it will be marked as interrupted by default
|
|
if (result.status == "interrupted")
|
|
return;
|
|
var error = (test.outcome() == "unexpected") ? this.buildError(result) : null;
|
|
this.testStructure.finishTest(new playwrightTestNode_1.default(test), error);
|
|
var suite = new playwrightSuitNode_1.default(test.parent);
|
|
// terminate all finished suites up the test structrure
|
|
while (suite !== undefined && suite.tests.every(function (t) { return t.status === testNodeStatus_1.default.Finished; }) &&
|
|
suite.suites.every(function (s) { return s.status === testNodeStatus_1.default.Finished; })) {
|
|
this.testStructure.finishSuite(suite);
|
|
if (suite.nativeSuite.parent === undefined)
|
|
suite = undefined;
|
|
else
|
|
suite = new playwrightSuitNode_1.default(suite.nativeSuite.parent);
|
|
}
|
|
};
|
|
PlaywrightJBReporter.prototype.onEnd = function (result) {
|
|
var _this = this;
|
|
if (this.globalErrors.length > 0) {
|
|
process.stderr.write(this.globalErrors.join("\n"), function () {
|
|
_this.testStructure.finishTesting();
|
|
});
|
|
}
|
|
else {
|
|
this.testStructure.finishTesting();
|
|
}
|
|
};
|
|
PlaywrightJBReporter.prototype.onError = function (error) {
|
|
var _a = this.normalizeFailureMessageAndStack(error.message, error.stack), message = _a[0], stack = _a[1];
|
|
this.globalErrors.push(message + stack);
|
|
};
|
|
PlaywrightJBReporter.prototype.buildError = function (result) {
|
|
var _this = this;
|
|
var _a;
|
|
var normalizedErrors = result.errors
|
|
.map(function (error) { return _this.normalizeFailureMessageAndStack(error.message, error.stack); });
|
|
var stack = (_a = normalizedErrors.map(function (value) { return value[1]; }).find(function (value) { return value != null; })) !== null && _a !== void 0 ? _a : "";
|
|
var message = normalizedErrors.map(function (value) { return value[0]; }).join("\n");
|
|
return {
|
|
name: 'Error',
|
|
message: message,
|
|
stack: stack
|
|
};
|
|
};
|
|
PlaywrightJBReporter.prototype.normalizeFailureMessageAndStack = function (message, stack) {
|
|
if (stack != null) {
|
|
if (stack.indexOf(message) === 0) {
|
|
stack = stack.substring(message.length);
|
|
}
|
|
else {
|
|
var newMessage = "Error: " + message;
|
|
if (stack.indexOf(newMessage) === 0) {
|
|
stack = stack.substring(newMessage.length);
|
|
message = newMessage;
|
|
}
|
|
}
|
|
}
|
|
if (message != null) {
|
|
message = message.replace(ansiRegex, '');
|
|
}
|
|
return [message, stack];
|
|
};
|
|
return PlaywrightJBReporter;
|
|
}());
|
|
module.exports = PlaywrightJBReporter;
|
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"playwrightReporter.js","sourceRoot":"","sources":["../../../src/playwright/playwrightReporter.ts"],"names":[],"mappings":"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","sourcesContent":["import PlaywrightSuitNode from \"./playwrightSuitNode\"\nimport PlaywrightTestNode from \"./playwrightTestNode\"\nimport PlaywrightTestStructure from \"./playwrightTestStructure\"\nimport TestNodeStatus from \"../core/testNodeStatus\"\nimport {FullConfig, FullResult, Reporter, Suite, TestCase, TestError, TestResult, TestStep} from \"@playwright/test/reporter\";\n\nconst ansiRegexPattern = [\n  '[\\\\u001B\\\\u009B][[\\\\]()#;?]*(?:(?:(?:(?:;[-a-zA-Z\\\\d\\\\/#&.:=?%@~_]+)*|[a-zA-Z\\\\d]+(?:;[-a-zA-Z\\\\d\\\\/#&.:=?%@~_]*)*)?\\\\u0007)',\n  '(?:(?:\\\\d{1,4}(?:;\\\\d{0,4})*)?[\\\\dA-PR-TZcf-ntqry=><~]))'\n].join('|');\n\nconst ansiRegex = new RegExp(ansiRegexPattern, 'g');\n\nclass PlaywrightJBReporter implements Reporter {\n\n  private readonly testStructure = new PlaywrightTestStructure();\n  private readonly globalErrors: Array<String> = [];\n\n  printsToStdio(): boolean {\n    return true\n  }\n\n  onStdErr(chunk: string | Buffer, test: void | TestCase, result: void | TestResult) {\n    if (test == null) {\n      return process.stderr.write(chunk);\n    }\n\n    if (chunk instanceof Buffer) {\n      chunk = chunk.toString();\n    }\n\n    this.testStructure.testStdErr(new PlaywrightTestNode(test as TestCase), chunk)\n  }\n\n  onStdOut(chunk: string | Buffer, test: void | TestCase, result: void | TestResult) {\n    if (test == null) {\n      return process.stdout.write(chunk);\n    }\n\n    if (chunk instanceof Buffer) {\n      chunk = chunk.toString();\n    }\n\n    this.testStructure.testStdOut(new PlaywrightTestNode(test as TestCase), chunk)\n  }\n\n  onBegin(config: FullConfig, suite: Suite) {\n    this.testStructure.startTesting(new PlaywrightSuitNode(suite))\n    // root\n    this.testStructure.startSuite(new PlaywrightSuitNode(suite))\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  onTestBegin(test: TestCase, result: TestResult): void {\n    let suite: PlaywrightSuitNode | undefined = new PlaywrightSuitNode(test.parent)\n    let suitesToStart: PlaywrightSuitNode[] = []\n\n    while (suite !== undefined && suite.status === TestNodeStatus.NotStarted) {\n      suitesToStart.push(suite)\n      if (suite.nativeSuite.parent === undefined) suite = undefined\n      else suite = new PlaywrightSuitNode(suite.nativeSuite.parent)\n    }\n\n    suitesToStart.reverse().forEach((suite: PlaywrightSuitNode) => {\n      this.testStructure.startSuite(suite)\n    })\n\n    this.testStructure.startTest(new PlaywrightTestNode(test))\n\n    if (test.expectedStatus == 'skipped') {\n      this.testStructure.ignoreTest(new PlaywrightTestNode(test))\n    }\n  }\n\n  onStepBegin(test: TestCase, result: TestResult, step: TestStep) {\n    this.testStructure.startStep(step)\n  }\n\n  onStepEnd(test: TestCase, result: TestResult, step: TestStep) {\n    this.testStructure.finishStep(step)\n  }\n\n  onTestEnd(test: TestCase, result: TestResult) {\n    // If the test status is interrupted, don't have to finish test in structure, it will be marked as interrupted by default\n    if (result.status == \"interrupted\") return;\n\n    const error: Error = (test.outcome() == \"unexpected\") ? this.buildError(result) : null;\n    this.testStructure.finishTest(new PlaywrightTestNode(test), error)\n\n    let suite: PlaywrightSuitNode | undefined = new PlaywrightSuitNode(test.parent)\n    // terminate all finished suites up the test structrure\n    while (suite !== undefined && suite.tests.every((t: PlaywrightTestNode) => t.status === TestNodeStatus.Finished) &&\n    suite.suites.every((s: PlaywrightSuitNode) => s.status === TestNodeStatus.Finished)) {\n      this.testStructure.finishSuite(suite)\n      if (suite.nativeSuite.parent === undefined) suite = undefined\n      else suite = new PlaywrightSuitNode(suite.nativeSuite.parent)\n    }\n  }\n\n  onEnd(result: FullResult) {\n    if (this.globalErrors.length > 0) {\n      process.stderr.write(this.globalErrors.join(\"\\n\"), () => {\n        this.testStructure.finishTesting()\n      });\n    }\n    else {\n      this.testStructure.finishTesting()\n    }\n  }\n\n  onError(error: TestError) {\n    const [message, stack] = this.normalizeFailureMessageAndStack(error.message, error.stack)\n    this.globalErrors.push(message + stack)\n  }\n\n  private buildError(result: TestResult): Error {\n    const normalizedErrors = result.errors\n      .map((error: Error) => this.normalizeFailureMessageAndStack(error.message, error.stack))\n\n    const stack = normalizedErrors.map(value => value[1]).find(value => value != null) ?? \"\"\n    const message = normalizedErrors.map(value => value[0]).join(\"\\n\")\n\n    return <Error>{\n      name: 'Error', //TODO: Clarify the name\n      message: message,\n      stack: stack\n    }\n  }\n\n  private normalizeFailureMessageAndStack(message ?: string, stack ?: string): [string, string] {\n    if (stack != null) {\n      if (stack.indexOf(message) === 0) {\n        stack = stack.substring(message.length);\n      }\n      else {\n        const newMessage = \"Error: \" + message;\n        if (stack.indexOf(newMessage) === 0) {\n          stack = stack.substring(newMessage.length);\n          message = newMessage;\n        }\n      }\n    }\n    if (message != null) {\n      message = message.replace(ansiRegex, '');\n    }\n    return [message, stack]\n  }\n}\n\nexport = PlaywrightJBReporter\n"]}
|