From e79a61cf80335498c3150dafd9036de8ec6b9914 Mon Sep 17 00:00:00 2001 From: Weijia Wang <381152119@qq.com> Date: Sat, 21 Oct 2017 11:13:04 +0800 Subject: [PATCH] buffer: buffer.transcode to use internal/errors MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit `buffer.transcode` is still using raw TypeError. This change is to convert it to use internal/errors. Ref: https://github.com/nodejs/node/issues/11273 PR-URL: https://github.com/nodejs/node/pull/16352 Reviewed-By: James M Snell Reviewed-By: Luigi Pinca Reviewed-By: Michaƫl Zasso Reviewed-By: Joyee Cheung Reviewed-By: Gireesh Punathil --- lib/buffer.js | 3 ++- test/parallel/test-icu-transcode.js | 9 +++++++-- 2 files changed, 9 insertions(+), 3 deletions(-) diff --git a/lib/buffer.js b/lib/buffer.js index 6a176756c01bfa..908e8b56e8182c 100644 --- a/lib/buffer.js +++ b/lib/buffer.js @@ -1562,7 +1562,8 @@ if (process.binding('config').hasIntl) { // Buffer instance. transcode = function transcode(source, fromEncoding, toEncoding) { if (!isUint8Array(source)) - throw new TypeError('"source" argument must be a Buffer or Uint8Array'); + throw new errors.TypeError('ERR_INVALID_ARG_TYPE', 'source', + ['Buffer', 'Uint8Array'], source); if (source.length === 0) return Buffer.alloc(0); fromEncoding = normalizeEncoding(fromEncoding) || fromEncoding; diff --git a/test/parallel/test-icu-transcode.js b/test/parallel/test-icu-transcode.js index ad2c7ff273eefd..4f51e7230452ce 100644 --- a/test/parallel/test-icu-transcode.js +++ b/test/parallel/test-icu-transcode.js @@ -41,9 +41,14 @@ for (const test in tests) { utf8_to_ucs2.toString('ucs2')); } -assert.throws( +common.expectsError( () => buffer.transcode(null, 'utf8', 'ascii'), - /^TypeError: "source" argument must be a Buffer or Uint8Array$/ + { + type: TypeError, + code: 'ERR_INVALID_ARG_TYPE', + message: 'The "source" argument must be one of type Buffer ' + + 'or Uint8Array. Received type null' + } ); assert.throws(