summaryrefslogtreecommitdiff
path: root/test/built-ins/TypedArray/prototype/subarray/BigInt/results-with-different-length.js
diff options
context:
space:
mode:
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.js58
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");
+});