]> zoso.dev Git - buffer.git/commitdiff
Fix error messages for invalid sizes (test-buffer-slow.js)
authorFeross Aboukhadijeh <feross@feross.org>
Fri, 16 Feb 2018 08:17:47 +0000 (00:17 -0800)
committerFeross Aboukhadijeh <feross@feross.org>
Fri, 16 Feb 2018 08:17:47 +0000 (00:17 -0800)
index.js
test/node/test-buffer-slow.js

index 1c783effba0fd01a112b8d60fdf1e41cbcd02e1c..8fdb388af6f8d427474c56fca069494f6c2960cb 100644 (file)
--- a/index.js
+++ b/index.js
@@ -69,7 +69,7 @@ Object.defineProperty(Buffer.prototype, 'offset', {
 
 function createBuffer (length) {
   if (length > K_MAX_LENGTH) {
-    throw new RangeError('Invalid typed array length')
+    throw new RangeError('The value "' + length + '" is invalid for option "size"')
   }
   // Return an augmented `Uint8Array` instance
   var buf = new Uint8Array(length)
@@ -153,7 +153,7 @@ function assertSize (size) {
   if (typeof size !== 'number') {
     throw new TypeError('"size" argument must be of type number')
   } else if (size < 0) {
-    throw new RangeError('"size" argument must not be negative')
+    throw new RangeError('The value "' + size + '" is invalid for option "size"')
   }
 }
 
index 65cea21ed1e2be4ff9f1920c4236e188e32054ea..4d739938985ca871b5788884fd4bad2e78a9f5ef 100644 (file)
@@ -1,21 +1,19 @@
 'use strict';
 var Buffer = require('../../').Buffer;
 
+const common = require('./common');
+const assert = require('assert');
+const buffer = require('../../');
+const SlowBuffer = buffer.SlowBuffer;
 
-
-var assert = require('assert');
-var buffer = require('../../');
-var Buffer = buffer.Buffer;
-var SlowBuffer = buffer.SlowBuffer;
-
-var ones = [1, 1, 1, 1];
+const ones = [1, 1, 1, 1];
 
 // should create a Buffer
-var sb = SlowBuffer(4);
+let sb = SlowBuffer(4);
 assert(sb instanceof Buffer);
 assert.strictEqual(sb.length, 4);
 sb.fill(1);
-for (var [key, value] of sb.entries()) {
+for (const [key, value] of sb.entries()) {
   assert.deepStrictEqual(value, ones[key]);
 }
 
@@ -27,7 +25,7 @@ sb = SlowBuffer(4);
 assert(sb instanceof Buffer);
 assert.strictEqual(sb.length, 4);
 sb.fill(1);
-for (var [key, value] of sb.entries()) {
+for (const [key, value] of sb.entries()) {
   assert.deepStrictEqual(value, ones[key]);
 }
 
@@ -37,7 +35,9 @@ try {
   assert.strictEqual(
     SlowBuffer(buffer.kMaxLength).length, buffer.kMaxLength);
 } catch (e) {
-  assert.equal(e.message, 'Array buffer allocation failed');
+  // Don't match on message as it is from the JavaScript engine. V8 and
+  // ChakraCore provide different messages.
+  assert.strictEqual(e.name, 'RangeError');
 }
 
 // should work with number-coercible values
@@ -51,13 +51,23 @@ assert.strictEqual(SlowBuffer({}).length, 0);
 assert.strictEqual(SlowBuffer('string').length, 0);
 
 // should throw with invalid length
+const bufferMaxSizeMsg = common.expectsError({
+  code: 'ERR_INVALID_OPT_VALUE',
+  type: RangeError,
+  message: /^The value "[^"]*" is invalid for option "size"$/
+}, 2);
 assert.throws(function() {
   SlowBuffer(Infinity);
-}, 'invalid Buffer length');
-assert.throws(function() {
+}, bufferMaxSizeMsg);
+common.expectsError(function() {
   SlowBuffer(-1);
-}, 'invalid Buffer length');
+}, {
+  code: 'ERR_INVALID_OPT_VALUE',
+  type: RangeError,
+  message: 'The value "-1" is invalid for option "size"'
+});
+
 assert.throws(function() {
   SlowBuffer(buffer.kMaxLength + 1);
-}, 'invalid Buffer length');
+}, bufferMaxSizeMsg);