@sgohlke/stryker-log-ignorer
Version:
Log Ignorer for Stryker
50 lines (38 loc) • 2.65 kB
JavaScript
;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