From 7b84363636843b6267f755c7023999ec67f981e2 Mon Sep 17 00:00:00 2001 From: Ali BARIN Date: Fri, 3 Mar 2017 13:43:16 +0100 Subject: [PATCH] util: fix inspecting symbol key in string PR-URL: https://github.com/nodejs/node/pull/11672 Reviewed-By: James M Snell Reviewed-By: Luigi Pinca Reviewed-By: Colin Ihrig --- lib/util.js | 4 ++++ test/parallel/test-util-inspect.js | 3 +++ 2 files changed, 7 insertions(+) diff --git a/lib/util.js b/lib/util.js index 64c4c94c29a81f..8c880c674b5ad3 100644 --- a/lib/util.js +++ b/lib/util.js @@ -396,6 +396,10 @@ function formatValue(ctx, value, recurseTimes) { // for boxed Strings, we have to remove the 0-n indexed entries, // since they just noisy up the output and are redundant keys = keys.filter(function(key) { + if (typeof key === 'symbol') { + return true; + } + return !(key >= 0 && key < raw.length); }); } diff --git a/test/parallel/test-util-inspect.js b/test/parallel/test-util-inspect.js index cf07f4c8213cee..33e0253a9e9b7c 100644 --- a/test/parallel/test-util-inspect.js +++ b/test/parallel/test-util-inspect.js @@ -50,6 +50,9 @@ assert.strictEqual(util.inspect(Object.create({}, {visible: {value: 1, enumerable: true}, hidden: {value: 2}})), '{ visible: 1 }' ); +assert.strictEqual(util.inspect(Object.assign(new String('hello'), + { [Symbol('foo')]: 123 }), { showHidden: true }), + '{ [String: \'hello\'] [length]: 5, [Symbol(foo)]: 123 }'); { const regexp = /regexp/;