|
| 1 | +'use strict'; |
| 2 | + |
| 3 | +require('../common'); |
| 4 | +const assert = require('assert'); |
| 5 | + |
| 6 | +assert.strictEqual(0, Buffer.from('hello').slice(0, 0).length); |
| 7 | +assert.strictEqual(0, Buffer('hello').slice(0, 0).length); |
| 8 | + |
| 9 | +const buf = Buffer.from('0123456789'); |
| 10 | +assert.equal(buf.slice(-10, 10), '0123456789'); |
| 11 | +assert.equal(buf.slice(-20, 10), '0123456789'); |
| 12 | +assert.equal(buf.slice(-20, -10), ''); |
| 13 | +assert.equal(buf.slice(), '0123456789'); |
| 14 | +assert.equal(buf.slice(0), '0123456789'); |
| 15 | +assert.equal(buf.slice(0, 0), ''); |
| 16 | +assert.equal(buf.slice(undefined), '0123456789'); |
| 17 | +assert.equal(buf.slice('foobar'), '0123456789'); |
| 18 | +assert.equal(buf.slice(undefined, undefined), '0123456789'); |
| 19 | + |
| 20 | +assert.equal(buf.slice(2), '23456789'); |
| 21 | +assert.equal(buf.slice(5), '56789'); |
| 22 | +assert.equal(buf.slice(10), ''); |
| 23 | +assert.equal(buf.slice(5, 8), '567'); |
| 24 | +assert.equal(buf.slice(8, -1), '8'); |
| 25 | +assert.equal(buf.slice(-10), '0123456789'); |
| 26 | +assert.equal(buf.slice(0, -9), '0'); |
| 27 | +assert.equal(buf.slice(0, -10), ''); |
| 28 | +assert.equal(buf.slice(0, -1), '012345678'); |
| 29 | +assert.equal(buf.slice(2, -2), '234567'); |
| 30 | +assert.equal(buf.slice(0, 65536), '0123456789'); |
| 31 | +assert.equal(buf.slice(65536, 0), ''); |
| 32 | +assert.equal(buf.slice(-5, -8), ''); |
| 33 | +assert.equal(buf.slice(-5, -3), '56'); |
| 34 | +assert.equal(buf.slice(-10, 10), '0123456789'); |
| 35 | +for (let i = 0, s = buf.toString(); i < buf.length; ++i) { |
| 36 | + assert.equal(buf.slice(i), s.slice(i)); |
| 37 | + assert.equal(buf.slice(0, i), s.slice(0, i)); |
| 38 | + assert.equal(buf.slice(-i), s.slice(-i)); |
| 39 | + assert.equal(buf.slice(0, -i), s.slice(0, -i)); |
| 40 | +} |
| 41 | + |
| 42 | +const utf16Buf = Buffer.from('0123456789', 'utf16le'); |
| 43 | +assert.deepStrictEqual(utf16Buf.slice(0, 6), Buffer.from('012', 'utf16le')); |
| 44 | + |
| 45 | +assert.equal(buf.slice('0', '1'), '0'); |
| 46 | +assert.equal(buf.slice('-5', '10'), '56789'); |
| 47 | +assert.equal(buf.slice('-10', '10'), '0123456789'); |
| 48 | +assert.equal(buf.slice('-10', '-5'), '01234'); |
| 49 | +assert.equal(buf.slice('-10', '-0'), ''); |
| 50 | +assert.equal(buf.slice('111'), ''); |
| 51 | +assert.equal(buf.slice('0', '-111'), ''); |
| 52 | + |
| 53 | +// try to slice a zero length Buffer |
| 54 | +// see https://github.com/joyent/node/issues/5881 |
| 55 | +Buffer.alloc(0).slice(0, 1); |
| 56 | + |
| 57 | +{ |
| 58 | + // Single argument slice |
| 59 | + assert.strictEqual('bcde', Buffer.from('abcde').slice(1).toString()); |
| 60 | +} |
| 61 | + |
| 62 | +// slice(0,0).length === 0 |
| 63 | +assert.strictEqual(0, Buffer.from('hello').slice(0, 0).length); |
0 commit comments