diff options
Diffstat (limited to 'test/built-ins/TypedArray/prototype/subarray/BigInt/results-with-different-length.js')
-rw-r--r-- | test/built-ins/TypedArray/prototype/subarray/BigInt/results-with-different-length.js | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/test/built-ins/TypedArray/prototype/subarray/BigInt/results-with-different-length.js b/test/built-ins/TypedArray/prototype/subarray/BigInt/results-with-different-length.js new file mode 100644 index 000000000..3be58ad56 --- /dev/null +++ b/test/built-ins/TypedArray/prototype/subarray/BigInt/results-with-different-length.js @@ -0,0 +1,58 @@ +// Copyright (C) 2016 the V8 project authors. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-%typedarray%.prototype.subarray +description: Subarray may return a new instance with a smaller length +info: | + 22.2.3.27 %TypedArray%.prototype.subarray( begin , end ) + + ... + 17. Return ? TypedArraySpeciesCreate(O, argumentsList). +includes: [testBigIntTypedArray.js, compareArray.js] +features: [BigInt, TypedArray] +---*/ + +testWithBigIntTypedArrayConstructors(function(TA) { + var sample = new TA(convertToBigInt([40, 41, 42, 43])); + + function testRes(result, expected, msg) { + assert(compareArray(result, expected), msg + ", result: [" + result + "]"); + } + + testRes(sample.subarray(1), convertToBigInt([41, 42, 43]), "begin == 1"); + testRes(sample.subarray(2), convertToBigInt([42, 43]), "begin == 2"); + testRes(sample.subarray(3), convertToBigInt([43]), "begin == 3"); + + testRes(sample.subarray(1, 4), convertToBigInt([41, 42, 43]), "begin == 1, end == length"); + testRes(sample.subarray(2, 4), convertToBigInt([42, 43]), "begin == 2, end == length"); + testRes(sample.subarray(3, 4), convertToBigInt([43]), "begin == 3, end == length"); + + testRes(sample.subarray(0, 1), convertToBigInt([40]), "begin == 0, end == 1"); + testRes(sample.subarray(0, 2), convertToBigInt([40, 41]), "begin == 0, end == 2"); + testRes(sample.subarray(0, 3), convertToBigInt([40, 41, 42]), "begin == 0, end == 3"); + + testRes(sample.subarray(-1), convertToBigInt([43]), "begin == -1"); + testRes(sample.subarray(-2), convertToBigInt([42, 43]), "begin == -2"); + testRes(sample.subarray(-3), convertToBigInt([41, 42, 43]), "begin == -3"); + + testRes(sample.subarray(-1, 4), convertToBigInt([43]), "begin == -1, end == length"); + testRes(sample.subarray(-2, 4), convertToBigInt([42, 43]), "begin == -2, end == length"); + testRes(sample.subarray(-3, 4), convertToBigInt([41, 42, 43]), "begin == -3, end == length"); + + testRes(sample.subarray(0, -1), convertToBigInt([40, 41, 42]), "begin == 0, end == -1"); + testRes(sample.subarray(0, -2), convertToBigInt([40, 41]), "begin == 0, end == -2"); + testRes(sample.subarray(0, -3), convertToBigInt([40]), "begin == 0, end == -3"); + + testRes(sample.subarray(-0, -1), convertToBigInt([40, 41, 42]), "begin == -0, end == -1"); + testRes(sample.subarray(-0, -2), convertToBigInt([40, 41]), "begin == -0, end == -2"); + testRes(sample.subarray(-0, -3), convertToBigInt([40]), "begin == -0, end == -3"); + + testRes(sample.subarray(-2, -1), convertToBigInt([42]), "length == 4, begin == -2, end == -1"); + testRes(sample.subarray(1, -1), convertToBigInt([41, 42]), "length == 4, begin == 1, end == -1"); + testRes(sample.subarray(1, -2), convertToBigInt([41]), "length == 4, begin == 1, end == -2"); + testRes(sample.subarray(2, -1), convertToBigInt([42]), "length == 4, begin == 2, end == -1"); + + testRes(sample.subarray(-1, 5), convertToBigInt([43]), "begin == -1, end > length"); + testRes(sample.subarray(-2, 4), convertToBigInt([42, 43]), "begin == -2, end > length"); + testRes(sample.subarray(-3, 4), convertToBigInt([41, 42, 43]), "begin == -3, end > length"); +}); |