filter-console
Version:
Filter out unwanted `console.log()` output
61 lines (51 loc) • 1.19 kB
JavaScript
import process from 'node:process';
import {format} from 'node:util';
export default function filterConsole(excludePatterns, options) {
options = {
console,
methods: [
'log',
'debug',
'info',
'warn',
'error',
],
...options,
};
const {console: consoleObject, methods} = options;
const originalMethods = methods.map(method => consoleObject[method]);
const check = string => {
for (const pattern of excludePatterns) {
if (typeof pattern === 'string') {
if (string.includes(pattern)) {
return true;
}
} else if (typeof pattern === 'function') {
if (pattern(string)) {
return true;
}
} else if (pattern.test(string)) {
return true;
}
}
return false;
};
for (const method of methods) {
const originalMethod = consoleObject[method];
consoleObject[method] = (...args) => {
if (check(format(...args))) {
return;
}
originalMethod(...args);
};
// Exposed for testing
if (process.env.NODE_ENV === 'test') {
consoleObject[method].original = originalMethod;
}
}
return () => {
for (const [index, method] of methods.entries()) {
consoleObject[method] = originalMethods[index];
}
};
}