UNPKG

creevey

Version:

creevey is a tool for automated visual testing, that tightly integrated with storybook

73 lines (56 loc) 17.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.TeamcityReporter = exports.CreeveyReporter = void 0; var _chalk = _interopRequireDefault(require("chalk")); var _mocha = require("mocha"); var _types = require("../../types"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } class CreeveyReporter extends _mocha.reporters.Base { constructor(runner, options) { super(runner); // eslint-disable-next-line @typescript-eslint/ban-ts-ignore //@ts-ignore Should update @types/mocha for new major release https://github.com/mochajs/mocha/releases/tag/v7.0.0 const topLevelSuite = options.reporterOption.topLevelSuite; runner.on('test', test => console.log(`[${_chalk.default.yellow('START')}:${topLevelSuite}:${process.pid}]`, _chalk.default.cyan(test.titlePath().join('/')))); runner.on('pass', test => console.log(`[${_chalk.default.green('PASS')}:${topLevelSuite}:${process.pid}]`, _chalk.default.cyan(test.titlePath().join('/')))); runner.on('fail', (test, error) => console.log(`[${_chalk.default.red('FAIL')}:${topLevelSuite}:${process.pid}]`, _chalk.default.cyan(test.titlePath().join('/')), error instanceof Error ? error.stack || error.message : error)); } } exports.CreeveyReporter = CreeveyReporter; class TeamcityReporter extends _mocha.reporters.Base { constructor(runner, options) { super(runner); // eslint-disable-next-line @typescript-eslint/ban-ts-ignore //@ts-ignore Should update @types/mocha for new major release https://github.com/mochajs/mocha/releases/tag/v7.0.0 _defineProperty(this, "escape", str => { if (!str) return ''; return str.toString() // eslint-disable-next-line no-control-regex .replace(/\x1B.*?m/g, '').replace(/\|/g, '||').replace(/\n/g, '|n').replace(/\r/g, '|r').replace(/\[/g, '|[').replace(/\]/g, '|]').replace(/\u0085/g, '|x').replace(/\u2028/g, '|l').replace(/\u2029/g, '|p').replace(/'/g, "|'"); }); const topLevelSuite = this.escape(options.reporterOption.topLevelSuite); // eslint-disable-next-line @typescript-eslint/ban-ts-ignore //@ts-ignore Should update @types/mocha for new major release https://github.com/mochajs/mocha/releases/tag/v7.0.0 const { reportDir, willRetry, images } = options.reporterOption; runner.on('suite', suite => suite.root ? console.log(`##teamcity[testSuiteStarted name='${topLevelSuite}' flowId='${process.pid}']`) : console.log(`##teamcity[testSuiteStarted name='${this.escape(suite.title)}' flowId='${process.pid}']`)); runner.on('test', test => console.log(`##teamcity[testStarted name='${this.escape(test.title)}' flowId='${process.pid}']`)); runner.on('fail', (test, error) => { Object.entries(images()).forEach(([name, image]) => { if (!image) return; const filePath = test.titlePath().concat(name == topLevelSuite ? [] : [topLevelSuite]).map(this.escape).join('/'); Object.values(image).filter(_types.isDefined).forEach(fileName => (console.log(`##teamcity[publishArtifacts '${reportDir}/${filePath}/${fileName} => report/${filePath}']`), console.log(`##teamcity[testMetadata testName='${this.escape(test.title)}' type='image' value='report/${filePath}/${fileName}' flowId='${process.pid}']`))); }); // Output failed test as passed due TC don't support retry mechanic // https://teamcity-support.jetbrains.com/hc/en-us/community/posts/207216829-Count-test-as-successful-if-at-least-one-try-is-successful?page=1#community_comment_207394125 willRetry() ? console.log(`##teamcity[testFinished name='${this.escape(test.title)}' flowId='${process.pid}']`) : console.log(`##teamcity[testFailed name='${this.escape(test.title)}' message='${this.escape(error.message)}' details='${this.escape(error.stack)}' flowId='${process.pid}']`); }); runner.on('pending', test => console.log(`##teamcity[testIgnored name='${this.escape(test.title)}' message='${this.escape(typeof test.skipReason == 'boolean' ? test.title : test.skipReason)}' flowId='${process.pid}']`)); runner.on('test end', test => console.log(`##teamcity[testFinished name='${this.escape(test.title)}' flowId='${process.pid}']`)); runner.on('suite end', suite => suite.root || console.log(`##teamcity[testSuiteFinished name='${this.escape(suite.title)}' flowId='${process.pid}']`)); runner.on('end', () => console.log(`##teamcity[testSuiteFinished name='${topLevelSuite}' flowId='${process.pid}']`)); } } exports.TeamcityReporter = TeamcityReporter; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/server/worker/reporter.ts"],"names":["CreeveyReporter","reporters","Base","constructor","runner","options","topLevelSuite","reporterOption","on","test","console","log","chalk","yellow","process","pid","cyan","titlePath","join","green","error","red","Error","stack","message","TeamcityReporter","str","toString","replace","escape","reportDir","willRetry","images","suite","root","title","Object","entries","forEach","name","image","filePath","concat","map","values","filter","isDefined","fileName","skipReason"],"mappings":"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","sourcesContent":["import chalk from 'chalk';\nimport { Runner, reporters, MochaOptions } from 'mocha';\nimport { Images, isDefined } from '../../types';\n\nexport class CreeveyReporter extends reporters.Base {\n  constructor(runner: Runner, options: MochaOptions) {\n    super(runner);\n\n    // eslint-disable-next-line @typescript-eslint/ban-ts-ignore\n    //@ts-ignore Should update @types/mocha for new major release https://github.com/mochajs/mocha/releases/tag/v7.0.0\n    const topLevelSuite = options.reporterOption.topLevelSuite;\n\n    runner.on('test', (test) =>\n      console.log(`[${chalk.yellow('START')}:${topLevelSuite}:${process.pid}]`, chalk.cyan(test.titlePath().join('/'))),\n    );\n    runner.on('pass', (test) =>\n      console.log(`[${chalk.green('PASS')}:${topLevelSuite}:${process.pid}]`, chalk.cyan(test.titlePath().join('/'))),\n    );\n    runner.on('fail', (test, error) =>\n      console.log(\n        `[${chalk.red('FAIL')}:${topLevelSuite}:${process.pid}]`,\n        chalk.cyan(test.titlePath().join('/')),\n        error instanceof Error ? error.stack || error.message : error,\n      ),\n    );\n  }\n}\n\nexport class TeamcityReporter extends reporters.Base {\n  constructor(runner: Runner, options: MochaOptions) {\n    super(runner);\n\n    // eslint-disable-next-line @typescript-eslint/ban-ts-ignore\n    //@ts-ignore Should update @types/mocha for new major release https://github.com/mochajs/mocha/releases/tag/v7.0.0\n    const topLevelSuite = this.escape(options.reporterOption.topLevelSuite);\n    // eslint-disable-next-line @typescript-eslint/ban-ts-ignore\n    //@ts-ignore Should update @types/mocha for new major release https://github.com/mochajs/mocha/releases/tag/v7.0.0\n    const { reportDir, willRetry, images } = options.reporterOption as {\n      reportDir: string;\n      willRetry: () => boolean;\n      images: () => Partial<{\n        [name: string]: Partial<Images>;\n      }>;\n    };\n\n    runner.on('suite', (suite) =>\n      suite.root\n        ? console.log(`##teamcity[testSuiteStarted name='${topLevelSuite}' flowId='${process.pid}']`)\n        : console.log(`##teamcity[testSuiteStarted name='${this.escape(suite.title)}' flowId='${process.pid}']`),\n    );\n\n    runner.on('test', (test) =>\n      console.log(`##teamcity[testStarted name='${this.escape(test.title)}' flowId='${process.pid}']`),\n    );\n\n    runner.on('fail', (test, error) => {\n      Object.entries(images()).forEach(([name, image]) => {\n        if (!image) return;\n        const filePath = test\n          .titlePath()\n          .concat(name == topLevelSuite ? [] : [topLevelSuite])\n          .map(this.escape)\n          .join('/');\n        Object.values(image)\n          .filter(isDefined)\n          .forEach(\n            (fileName) => (\n              console.log(`##teamcity[publishArtifacts '${reportDir}/${filePath}/${fileName} => report/${filePath}']`),\n              console.log(\n                `##teamcity[testMetadata testName='${this.escape(\n                  test.title,\n                )}' type='image' value='report/${filePath}/${fileName}' flowId='${process.pid}']`,\n              )\n            ),\n          );\n      });\n\n      // Output failed test as passed due TC don't support retry mechanic\n      // https://teamcity-support.jetbrains.com/hc/en-us/community/posts/207216829-Count-test-as-successful-if-at-least-one-try-is-successful?page=1#community_comment_207394125\n      willRetry()\n        ? console.log(`##teamcity[testFinished name='${this.escape(test.title)}' flowId='${process.pid}']`)\n        : console.log(\n            `##teamcity[testFailed name='${this.escape(test.title)}' message='${this.escape(\n              error.message,\n            )}' details='${this.escape(error.stack)}' flowId='${process.pid}']`,\n          );\n    });\n\n    runner.on('pending', (test) =>\n      console.log(\n        `##teamcity[testIgnored name='${this.escape(test.title)}' message='${this.escape(\n          typeof test.skipReason == 'boolean' ? test.title : test.skipReason,\n        )}' flowId='${process.pid}']`,\n      ),\n    );\n\n    runner.on('test end', (test) =>\n      console.log(`##teamcity[testFinished name='${this.escape(test.title)}' flowId='${process.pid}']`),\n    );\n\n    runner.on(\n      'suite end',\n      (suite) =>\n        suite.root ||\n        console.log(`##teamcity[testSuiteFinished name='${this.escape(suite.title)}' flowId='${process.pid}']`),\n    );\n\n    runner.on('end', () =>\n      console.log(`##teamcity[testSuiteFinished name='${topLevelSuite}' flowId='${process.pid}']`),\n    );\n  }\n\n  private escape = (str: string): string => {\n    if (!str) return '';\n    return (\n      str\n        .toString()\n        // eslint-disable-next-line no-control-regex\n        .replace(/\\x1B.*?m/g, '')\n        .replace(/\\|/g, '||')\n        .replace(/\\n/g, '|n')\n        .replace(/\\r/g, '|r')\n        .replace(/\\[/g, '|[')\n        .replace(/\\]/g, '|]')\n        .replace(/\\u0085/g, '|x')\n        .replace(/\\u2028/g, '|l')\n        .replace(/\\u2029/g, '|p')\n        .replace(/'/g, \"|'\")\n    );\n  };\n}\n"]}