From 2251c71863463a7ccf3a2640036a1d24d7638298 Mon Sep 17 00:00:00 2001 From: Anna Henningsen Date: Sun, 25 Aug 2019 21:44:59 +0200 Subject: [PATCH] util: do not throw when inspecting detached ArrayBuffer --- lib/internal/util/inspect.js | 7 ++++++- test/parallel/test-util-inspect.js | 10 ++++++++++ 2 files changed, 16 insertions(+), 1 deletion(-) diff --git a/lib/internal/util/inspect.js b/lib/internal/util/inspect.js index 2f3b6cd11d8eb5..8ab3df8b631b7a 100644 --- a/lib/internal/util/inspect.js +++ b/lib/internal/util/inspect.js @@ -1189,7 +1189,12 @@ function formatSpecialArray(ctx, value, recurseTimes, maxLength, output, i) { } function formatArrayBuffer(ctx, value) { - const buffer = new Uint8Array(value); + let buffer; + try { + buffer = new Uint8Array(value); + } catch { + return [ctx.stylize('(detached)', 'special')]; + } if (hexSlice === undefined) hexSlice = uncurryThis(require('buffer').Buffer.prototype.hexSlice); let str = hexSlice(buffer, 0, Math.min(ctx.maxArrayLength, buffer.length)) diff --git a/test/parallel/test-util-inspect.js b/test/parallel/test-util-inspect.js index e843cc49a82040..64682d9c17d6d7 100644 --- a/test/parallel/test-util-inspect.js +++ b/test/parallel/test-util-inspect.js @@ -28,6 +28,7 @@ const util = require('util'); const vm = require('vm'); const { previewEntries } = internalBinding('util'); const { inspect } = util; +const { MessageChannel } = require('worker_threads'); assert.strictEqual(util.inspect(1), '1'); assert.strictEqual(util.inspect(false), 'false'); @@ -198,6 +199,15 @@ assert(!/Object/.test( ' y: 1337\n}'); } +{ + const ab = new ArrayBuffer(42); + assert.strictEqual(ab.byteLength, 42); + new MessageChannel().port1.postMessage(ab, [ ab ]); + assert.strictEqual(ab.byteLength, 0); + assert.strictEqual(util.inspect(ab), + 'ArrayBuffer { (detached), byteLength: 0 }'); +} + // Now do the same checks but from a different context. { const showHidden = false;