UNPKG

@sgohlke/stryker-log-ignorer

Version:
50 lines (38 loc) 2.65 kB
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; } var _class;// src/index.ts var _plugin = require('@stryker-mutator/api/plugin'); var _fs = require('fs'); var _fs2 = _interopRequireDefault(_fs); var LogIgnorer = (_class = class { static __initStatic() {this.inject = [_plugin.commonTokens.options]} constructor(options) { this.options = _optionalChain([options, 'optionalAccess', _ => _.logignore]); } shouldIgnore(path) { const loggerObjectNames = _nullishCoalesce(_optionalChain([this, 'access', _2 => _2.options, 'optionalAccess', _3 => _3.objectNames]), () => ( ["console"])); if (path.isExpressionStatement() && path.node.expression.type === "CallExpression" && path.node.expression.callee.type === "MemberExpression" && path.node.expression.callee.object.type === "Identifier" && loggerObjectNames.includes(path.node.expression.callee.object.name)) { return `We are not interested in testing ${loggerObjectNames} statements.`; } } }, _class.__initStatic(), _class); logIgnorerFactory.inject = _plugin.tokens.call(void 0, _plugin.commonTokens.injector); function logIgnorerFactory(injector) { return injector.injectClass(LogIgnorer); } function createLogIgnorerFactory() { return logIgnorerFactory; } var strykerPlugins = [ _plugin.declareFactoryPlugin.call(void 0, _plugin.PluginKind.Ignore, "log-ignore", createLogIgnorerFactory() ) ]; var strykerValidationSchema = JSON.parse( // eslint-disable-next-line security/detect-non-literal-fs-filename _fs2.default.readFileSync( new URL("../schema/log-ignorer-options.json", import.meta.url), "utf8" ) ); exports.LogIgnorer = LogIgnorer; exports.createLogIgnorerFactory = createLogIgnorerFactory; exports.logIgnorerFactory = logIgnorerFactory; exports.strykerPlugins = strykerPlugins; exports.strykerValidationSchema = strykerValidationSchema; //# sourceMappingURL=index.cjs.map