Skip to content

Commit

Permalink
diagnostics_channel: capture console messages
Browse files Browse the repository at this point in the history
  • Loading branch information
Qard committed Dec 17, 2024
1 parent 2cd385e commit 6ba11e5
Show file tree
Hide file tree
Showing 2 changed files with 114 additions and 3 deletions.
35 changes: 32 additions & 3 deletions lib/internal/console/constructor.js
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,13 @@ const {
} = require('internal/constants');
const kCounts = Symbol('counts');
const { time, timeLog, timeEnd, kNone } = require('internal/util/debuglog');
const { channel } = require('diagnostics_channel');

const onLog = channel('console.log');
const onWarn = channel('console.warn');
const onError = channel('console.error');
const onInfo = channel('console.info');
const onDebug = channel('console.debug');

const kTraceConsoleCategory = 'node,node.console';

Expand Down Expand Up @@ -371,14 +378,39 @@ function timeLogImpl(consoleRef, label, formatted, args) {

const consoleMethods = {
log(...args) {
if (onLog.hasSubscribers) {
onLog.publish(args);
}
this[kWriteToConsole](kUseStdout, this[kFormatForStdout](args));
},

info(...args) {
if (onInfo.hasSubscribers) {
onInfo.publish(args);
}
this[kWriteToConsole](kUseStdout, this[kFormatForStdout](args));
},

debug(...args) {
if (onDebug.hasSubscribers) {
onDebug.publish(args);
}
this[kWriteToConsole](kUseStdout, this[kFormatForStdout](args));
},

warn(...args) {
if (onWarn.hasSubscribers) {
onWarn.publish(args);
}
this[kWriteToConsole](kUseStderr, this[kFormatForStderr](args));
},

error(...args) {
if (onError.hasSubscribers) {
onError.publish(args);
}
this[kWriteToConsole](kUseStderr, this[kFormatForStderr](args));
},

dir(object, options) {
this[kWriteToConsole](kUseStdout, inspect(object, {
Expand Down Expand Up @@ -614,10 +646,7 @@ function noop() {}
for (const method of ReflectOwnKeys(consoleMethods))
Console.prototype[method] = consoleMethods[method];

Console.prototype.debug = Console.prototype.log;
Console.prototype.info = Console.prototype.log;
Console.prototype.dirxml = Console.prototype.log;
Console.prototype.error = Console.prototype.warn;
Console.prototype.groupCollapsed = Console.prototype.group;

function initializeGlobalConsole(globalConsole) {
Expand Down
82 changes: 82 additions & 0 deletions test/parallel/test-console-diagnostics-channels.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
'use strict';

const { mustCall } = require('../common');
const { deepStrictEqual, strictEqual, match, ok } = require('assert');
const { formatWithOptions } = require('util');

const { channel } = require('diagnostics_channel');

const {
hijackStdout,
hijackStderr,
restoreStdout,
restoreStderr
} = require('../common/hijackstdio');

const stdoutMethods = [
'log',
'info',
'debug'
];

const stderrMethods = [
'warn',
'error'
];

const methods = [
...stdoutMethods,
...stderrMethods
];

const channels = {
log: channel('console.log'),
info: channel('console.info'),
debug: channel('console.debug'),
warn: channel('console.warn'),
error: channel('console.error')
}

process.stdout.isTTY = false;
process.stderr.isTTY = false;

for (const method of methods) {
let intercepted = false;
let formatted = false;

const hijack = stdoutMethods.includes(method)
? hijackStdout
: hijackStderr;

const restore = stdoutMethods.includes(method)
? restoreStdout
: restoreStderr;

const foo = 'string';
const bar = { key: /value/ };
const baz = [ 1, 2, 3 ];

channels[method].subscribe(mustCall((args) => {
// Should not have been formatted yet.
intercepted = true;
ok(!formatted);

// Should receive expected log message args.
deepStrictEqual(args, [foo, bar, baz]);

// Should be able to mutate message args and have it reflected in output.
bar.added = true;
}));

hijack(mustCall((output) => {
// Should have already been intercepted.
formatted = true;
ok(intercepted);

// Should produce expected formatted output with mutated message args.
deepStrictEqual(output, 'string { key: /value/, added: true } [ 1, 2, 3 ]\n');
}));

console[method](foo, bar, baz);
restore();
}

0 comments on commit 6ba11e5

Please sign in to comment.