blob: f48e48d9e8cd35a20ea7ba4f0cd4c1d2a60da9f8 [file] [log] [blame]
// Copyright (C) 2017 André Bargull. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
esid: sec-array.prototype.splice
description: >
Length and deleteCount are both clamped to 2^53-1 when they exceed the integer limit.
info: |
...
2. Let len be ? ToLength(? Get(O, "length")).
...
7. Else,
a. Let insertCount be the number of actual arguments minus 2.
b. Let dc be ? ToInteger(deleteCount).
c. Let actualDeleteCount be min(max(dc, 0), len - actualStart).
...
11. Repeat, while k < actualDeleteCount
a. Let from be ! ToString(actualStart+k).
b. Let fromPresent be ? HasProperty(O, from).
c. If fromPresent is true, then
i. Let fromValue be ? Get(O, from).
ii. Perform ? CreateDataPropertyOrThrow(A, ! ToString(k), fromValue).
d. Increment k by 1.
...
includes: [compareArray.js]
---*/
var arrayLike = {
"9007199254740988": "9007199254740988",
"9007199254740989": "9007199254740989",
"9007199254740990": "9007199254740990",
"9007199254740991": "9007199254740991",
length: 2**53 + 2,
};
var result = Array.prototype.splice.call(arrayLike, 9007199254740989, 2**53 + 4);
assert.compareArray(result, [ "9007199254740989", "9007199254740990" ],
"arrayLike['9007199254740989'] and arrayLike['9007199254740990'] are removed");
assert.sameValue(arrayLike.length, 2**53 - 3,
"New length is 2**53 - 3");
assert.sameValue(arrayLike["9007199254740988"], "9007199254740988",
"arrayLike['9007199254740988'] is unchanged");
assert.sameValue("9007199254740989" in arrayLike, false,
"arrayLike['9007199254740989'] is removed");
assert.sameValue("9007199254740990" in arrayLike, false,
"arrayLike['9007199254740990'] is removed");
assert.sameValue(arrayLike["9007199254740991"], "9007199254740991",
"arrayLike['9007199254740991'] is unchanged");