summaryrefslogtreecommitdiffstats
path: root/js/src/tests/test262/built-ins/Array/prototype/toReversed/get-descending-order.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/src/tests/test262/built-ins/Array/prototype/toReversed/get-descending-order.js')
-rw-r--r--js/src/tests/test262/built-ins/Array/prototype/toReversed/get-descending-order.js51
1 files changed, 51 insertions, 0 deletions
diff --git a/js/src/tests/test262/built-ins/Array/prototype/toReversed/get-descending-order.js b/js/src/tests/test262/built-ins/Array/prototype/toReversed/get-descending-order.js
new file mode 100644
index 0000000000..81c46bf65a
--- /dev/null
+++ b/js/src/tests/test262/built-ins/Array/prototype/toReversed/get-descending-order.js
@@ -0,0 +1,51 @@
+// Copyright (C) 2021 Igalia, S.L. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-array.prototype.toReversed
+description: >
+ Array.prototype.toReversed gets the array elements from the last one to the first one.
+info: |
+ Array.prototype.toReversed ( )
+
+ ...
+ 2. Let len be ? LengthOfArrayLike(O).
+ ...
+ 5. Repeat, while k < len
+ a. Let from be ! ToString(𝔽(len - k - 1)).
+ ...
+ c. Let fromValue be ? Get(O, from).
+ ...
+features: [change-array-by-copy]
+includes: [compareArray.js]
+---*/
+
+var order = [];
+var arrayLike = {
+ length: 3,
+ get 0() {
+ order.push(0);
+ },
+ get 1() {
+ order.push(1);
+ },
+ get 2() {
+ order.push(2);
+ },
+};
+
+Array.prototype.toReversed.call(arrayLike);
+
+assert.compareArray(order, [2, 1, 0]);
+
+order = [];
+var arr = [0, 1, 2];
+Object.defineProperty(arr, 0, { get: function() { order.push(0); } });
+Object.defineProperty(arr, 1, { get: function() { order.push(1); } });
+Object.defineProperty(arr, 2, { get: function() { order.push(2); } });
+
+Array.prototype.toReversed.call(arr);
+
+assert.compareArray(order, [2, 1, 0]);
+
+reportCompare(0, 0);