From 2570f95ad14b91e0095a12d418580e6852345389 Mon Sep 17 00:00:00 2001 From: Jordan Harband Date: Tue, 14 Jan 2025 16:16:48 -0800 Subject: [PATCH] util: do not crash on inspecting function with `Symbol` name Refs: https://github.com/nodejs/node/issues/56570 PR-URL: https://github.com/nodejs/node/pull/56572 Reviewed-By: James M Snell Reviewed-By: Antoine du Hamel Reviewed-By: Luigi Pinca Reviewed-By: Ruben Bridgewater --- lib/internal/util/inspect.js | 6 +++--- test/parallel/test-util-inspect.js | 10 ++++++++++ 2 files changed, 13 insertions(+), 3 deletions(-) diff --git a/lib/internal/util/inspect.js b/lib/internal/util/inspect.js index cc76bbeed9b..743dc1fef23 100644 --- a/lib/internal/util/inspect.js +++ b/lib/internal/util/inspect.js @@ -989,7 +989,7 @@ function formatRaw(ctx, value, recurseTimes, typedArray) { keys = getKeys(value, ctx.showHidden); braces = ['{', '}']; if (typeof value === 'function') { - base = getFunctionBase(value, constructor, tag); + base = getFunctionBase(ctx, value, constructor, tag); if (keys.length === 0 && protoProps === undefined) return ctx.stylize(base, 'special'); } else if (constructor === 'Object') { @@ -1223,7 +1223,7 @@ function getClassBase(value, constructor, tag) { return `[${base}]`; } -function getFunctionBase(value, constructor, tag) { +function getFunctionBase(ctx, value, constructor, tag) { const stringified = FunctionPrototypeToString(value); if (StringPrototypeStartsWith(stringified, 'class') && stringified[stringified.length - 1] === '}') { const slice = StringPrototypeSlice(stringified, 5, -1); @@ -1250,7 +1250,7 @@ function getFunctionBase(value, constructor, tag) { if (value.name === '') { base += ' (anonymous)'; } else { - base += `: ${value.name}`; + base += `: ${typeof value.name === 'string' ? value.name : formatValue(ctx, value.name)}`; } base += ']'; if (constructor !== type && constructor !== null) { diff --git a/test/parallel/test-util-inspect.js b/test/parallel/test-util-inspect.js index 94064d94918..9549bba2737 100644 --- a/test/parallel/test-util-inspect.js +++ b/test/parallel/test-util-inspect.js @@ -3426,3 +3426,13 @@ assert.strictEqual( Object.defineProperty(BuiltinPrototype, 'constructor', desc); } } + +{ + function f() {} + Object.defineProperty(f, 'name', { value: Symbol('f') }); + + assert.strictEqual( + util.inspect(f), + '[Function: Symbol(f)]', + ); +}