mirror of https://github.com/lukechilds/node.git
Browse Source
Increase coverage of lib/buffer.js. PR-URL: https://github.com/nodejs/node/pull/12714 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>v6
David Cai
8 years ago
3 changed files with 95 additions and 6 deletions
@ -0,0 +1,25 @@ |
|||||
|
'use strict'; |
||||
|
|
||||
|
require('../common'); |
||||
|
const assert = require('assert'); |
||||
|
|
||||
|
// utf8, ucs2, ascii, latin1, utf16le
|
||||
|
const encodings = ['utf8', 'ucs2', 'ucs-2', 'ascii', 'latin1', 'binary', |
||||
|
'utf16le', 'utf-16le']; |
||||
|
|
||||
|
encodings |
||||
|
.reduce((es, e) => es.concat(e, e.toUpperCase()), []) |
||||
|
.forEach((encoding) => { |
||||
|
assert.strictEqual(Buffer.from('foo', encoding).toString(encoding), 'foo'); |
||||
|
}); |
||||
|
|
||||
|
// base64
|
||||
|
['base64', 'BASE64'].forEach((encoding) => { |
||||
|
assert.strictEqual(Buffer.from('Zm9v', encoding).toString(encoding), 'Zm9v'); |
||||
|
}); |
||||
|
|
||||
|
// hex
|
||||
|
['hex', 'HEX'].forEach((encoding) => { |
||||
|
assert.strictEqual(Buffer.from('666f6f', encoding).toString(encoding), |
||||
|
'666f6f'); |
||||
|
}); |
@ -0,0 +1,55 @@ |
|||||
|
'use strict'; |
||||
|
|
||||
|
require('../common'); |
||||
|
const assert = require('assert'); |
||||
|
|
||||
|
const outsideBounds = /^RangeError: Attempt to write outside buffer bounds$/; |
||||
|
|
||||
|
assert.throws(() => Buffer.alloc(9).write('foo', -1), outsideBounds); |
||||
|
assert.throws(() => Buffer.alloc(9).write('foo', 10), outsideBounds); |
||||
|
|
||||
|
const resultMap = new Map([ |
||||
|
['utf8', Buffer.from([102, 111, 111, 0, 0, 0, 0, 0, 0])], |
||||
|
['ucs2', Buffer.from([102, 0, 111, 0, 111, 0, 0, 0, 0])], |
||||
|
['ascii', Buffer.from([102, 111, 111, 0, 0, 0, 0, 0, 0])], |
||||
|
['latin1', Buffer.from([102, 111, 111, 0, 0, 0, 0, 0, 0])], |
||||
|
['binary', Buffer.from([102, 111, 111, 0, 0, 0, 0, 0, 0])], |
||||
|
['utf16le', Buffer.from([102, 0, 111, 0, 111, 0, 0, 0, 0])], |
||||
|
['base64', Buffer.from([102, 111, 111, 0, 0, 0, 0, 0, 0])], |
||||
|
['hex', Buffer.from([102, 111, 111, 0, 0, 0, 0, 0, 0])] |
||||
|
]); |
||||
|
|
||||
|
// utf8, ucs2, ascii, latin1, utf16le
|
||||
|
const encodings = ['utf8', 'utf-8', 'ucs2', 'ucs-2', 'ascii', 'latin1', |
||||
|
'binary', 'utf16le', 'utf-16le']; |
||||
|
|
||||
|
encodings |
||||
|
.reduce((es, e) => es.concat(e, e.toUpperCase()), []) |
||||
|
.forEach((encoding) => { |
||||
|
const buf = Buffer.alloc(9); |
||||
|
const len = Buffer.byteLength('foo', encoding); |
||||
|
assert.strictEqual(buf.write('foo', 0, len, encoding), len); |
||||
|
|
||||
|
if (encoding.indexOf('-') !== -1) |
||||
|
encoding = encoding.replace('-', ''); |
||||
|
|
||||
|
assert.deepStrictEqual(buf, resultMap.get(encoding.toLowerCase())); |
||||
|
}); |
||||
|
|
||||
|
// base64
|
||||
|
['base64', 'BASE64'].forEach((encoding) => { |
||||
|
const buf = Buffer.alloc(9); |
||||
|
const len = Buffer.byteLength('Zm9v', encoding); |
||||
|
|
||||
|
assert.strictEqual(buf.write('Zm9v', 0, len, encoding), len); |
||||
|
assert.deepStrictEqual(buf, resultMap.get(encoding.toLowerCase())); |
||||
|
}); |
||||
|
|
||||
|
// hex
|
||||
|
['hex', 'HEX'].forEach((encoding) => { |
||||
|
const buf = Buffer.alloc(9); |
||||
|
const len = Buffer.byteLength('666f6f', encoding); |
||||
|
|
||||
|
assert.strictEqual(buf.write('666f6f', 0, len, encoding), len); |
||||
|
assert.deepStrictEqual(buf, resultMap.get(encoding.toLowerCase())); |
||||
|
}); |
Loading…
Reference in new issue