Skip to content

Commit a04721d

Browse files
thefourtheyetrevnorris
authored andcommitted
test: check range fix for slowToString
Verify that start and end are coerced properly. Ref: #2919 PR-URL: #4019 Reviewed-By: Trevor Norris <[email protected]>
1 parent ec83654 commit a04721d

File tree

1 file changed

+75
-6
lines changed

1 file changed

+75
-6
lines changed

test/parallel/test-buffer.js

+75-6
Original file line numberDiff line numberDiff line change
@@ -248,14 +248,83 @@ b.copy(new Buffer(1), 1, 1, 1);
248248
// try to copy 0 bytes from past the end of the source buffer
249249
b.copy(new Buffer(1), 0, 2048, 2048);
250250

251-
// try to toString() a 0-length slice of a buffer, both within and without the
252-
// valid buffer range
253-
assert.equal(new Buffer('abc').toString('ascii', 0, 0), '');
254-
assert.equal(new Buffer('abc').toString('ascii', -100, -100), '');
255-
assert.equal(new Buffer('abc').toString('ascii', 100, 100), '');
251+
const rangeBuffer = new Buffer('abc');
252+
253+
// if start >= buffer's length, empty string will be returned
254+
assert.equal(rangeBuffer.toString('ascii', 3), '');
255+
assert.equal(rangeBuffer.toString('ascii', +Infinity), '');
256+
assert.equal(rangeBuffer.toString('ascii', 3.14, 3), '');
257+
assert.equal(rangeBuffer.toString('ascii', 'Infinity', 3), '');
258+
259+
// if end <= 0, empty string will be returned
260+
assert.equal(rangeBuffer.toString('ascii', 1, 0), '');
261+
assert.equal(rangeBuffer.toString('ascii', 1, -1.2), '');
262+
assert.equal(rangeBuffer.toString('ascii', 1, -100), '');
263+
assert.equal(rangeBuffer.toString('ascii', 1, -Infinity), '');
264+
265+
// if start < 0, start will be taken as zero
266+
assert.equal(rangeBuffer.toString('ascii', -1, 3), 'abc');
267+
assert.equal(rangeBuffer.toString('ascii', -1.99, 3), 'abc');
268+
assert.equal(rangeBuffer.toString('ascii', -Infinity, 3), 'abc');
269+
assert.equal(rangeBuffer.toString('ascii', '-1', 3), 'abc');
270+
assert.equal(rangeBuffer.toString('ascii', '-1.99', 3), 'abc');
271+
assert.equal(rangeBuffer.toString('ascii', '-Infinity', 3), 'abc');
272+
273+
// if start is an invalid integer, start will be taken as zero
274+
assert.equal(rangeBuffer.toString('ascii', 'node.js', 3), 'abc');
275+
assert.equal(rangeBuffer.toString('ascii', {}, 3), 'abc');
276+
assert.equal(rangeBuffer.toString('ascii', [], 3), 'abc');
277+
assert.equal(rangeBuffer.toString('ascii', NaN, 3), 'abc');
278+
assert.equal(rangeBuffer.toString('ascii', null, 3), 'abc');
279+
assert.equal(rangeBuffer.toString('ascii', undefined, 3), 'abc');
280+
assert.equal(rangeBuffer.toString('ascii', false, 3), 'abc');
281+
assert.equal(rangeBuffer.toString('ascii', '', 3), 'abc');
282+
283+
// but, if start is an integer when coerced, then it will be coerced and used.
284+
assert.equal(rangeBuffer.toString('ascii', '-1', 3), 'abc');
285+
assert.equal(rangeBuffer.toString('ascii', '1', 3), 'bc');
286+
assert.equal(rangeBuffer.toString('ascii', '-Infinity', 3), 'abc');
287+
assert.equal(rangeBuffer.toString('ascii', '3', 3), '');
288+
assert.equal(rangeBuffer.toString('ascii', Number(3), 3), '');
289+
assert.equal(rangeBuffer.toString('ascii', '3.14', 3), '');
290+
assert.equal(rangeBuffer.toString('ascii', '1.99', 3), 'bc');
291+
assert.equal(rangeBuffer.toString('ascii', '-1.99', 3), 'abc');
292+
assert.equal(rangeBuffer.toString('ascii', 1.99, 3), 'bc');
293+
assert.equal(rangeBuffer.toString('ascii', true, 3), 'bc');
294+
295+
// if end > buffer's length, end will be taken as buffer's length
296+
assert.equal(rangeBuffer.toString('ascii', 0, 5), 'abc');
297+
assert.equal(rangeBuffer.toString('ascii', 0, 6.99), 'abc');
298+
assert.equal(rangeBuffer.toString('ascii', 0, Infinity), 'abc');
299+
assert.equal(rangeBuffer.toString('ascii', 0, '5'), 'abc');
300+
assert.equal(rangeBuffer.toString('ascii', 0, '6.99'), 'abc');
301+
assert.equal(rangeBuffer.toString('ascii', 0, 'Infinity'), 'abc');
302+
303+
// if end is an invalid integer, end will be taken as buffer's length
304+
assert.equal(rangeBuffer.toString('ascii', 0, 'node.js'), '');
305+
assert.equal(rangeBuffer.toString('ascii', 0, {}), '');
306+
assert.equal(rangeBuffer.toString('ascii', 0, NaN), '');
307+
assert.equal(rangeBuffer.toString('ascii', 0, undefined), 'abc');
308+
assert.equal(rangeBuffer.toString('ascii', 0), 'abc');
309+
assert.equal(rangeBuffer.toString('ascii', 0, null), '');
310+
assert.equal(rangeBuffer.toString('ascii', 0, []), '');
311+
assert.equal(rangeBuffer.toString('ascii', 0, false), '');
312+
assert.equal(rangeBuffer.toString('ascii', 0, ''), '');
313+
314+
// but, if end is an integer when coerced, then it will be coerced and used.
315+
assert.equal(rangeBuffer.toString('ascii', 0, '-1'), '');
316+
assert.equal(rangeBuffer.toString('ascii', 0, '1'), 'a');
317+
assert.equal(rangeBuffer.toString('ascii', 0, '-Infinity'), '');
318+
assert.equal(rangeBuffer.toString('ascii', 0, '3'), 'abc');
319+
assert.equal(rangeBuffer.toString('ascii', 0, Number(3)), 'abc');
320+
assert.equal(rangeBuffer.toString('ascii', 0, '3.14'), 'abc');
321+
assert.equal(rangeBuffer.toString('ascii', 0, '1.99'), 'a');
322+
assert.equal(rangeBuffer.toString('ascii', 0, '-1.99'), '');
323+
assert.equal(rangeBuffer.toString('ascii', 0, 1.99), 'a');
324+
assert.equal(rangeBuffer.toString('ascii', 0, true), 'a');
256325

257326
// try toString() with a object as a encoding
258-
assert.equal(new Buffer('abc').toString({toString: function() {
327+
assert.equal(rangeBuffer.toString({toString: function() {
259328
return 'ascii';
260329
}}), 'abc');
261330

0 commit comments

Comments
 (0)