| // Copyright 2018 the V8 project authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| // Flags: --allow-natives-syntax |
| |
| // Ensure `Array.prototype.fill` functions correctly for numerous elements |
| // kinds. |
| |
| // If no arguments are provided, call Array.p.fill without any arguments, |
| // otherwise the test is allowed to specify what value to use to better control |
| // ElementsKind transitions. From and to is provided by the harness. |
| function callAndAssertFill(object, test_value, harness_value, from, to) { |
| let value = arguments.length > 2 ? test_value : harness_value; |
| |
| Array.prototype.fill.call(object, value, from, to); |
| |
| %HeapObjectVerify(object); |
| assertArrayHasValueInRange(object, value, from, to); |
| } |
| |
| function assertArrayHasValueInRange(obj, value, from, to) { |
| for (let i = from; i < to; ++i) { |
| assertEquals(value, obj[i]); |
| } |
| } |
| |
| // Tests are executed multiple times. Creating arrays using literal notation |
| // will create COW-Arrays, which will propagate the most general ElementsKind |
| // back to their allocation site. |
| // pristineArray will always return a 🐄-Array with the ElementsKind we actually |
| // want. |
| let i = 0; |
| function pristineArray(str) { |
| return eval(str + "//" + (i++)); |
| } |
| |
| let tests = { |
| ARRAY_PACKED_ELEMENTS(value, from, to) { |
| let array = pristineArray( |
| `["Some string", {}, /foobar/, "Another string", {}]`); |
| assertTrue(%HasObjectElements(array)); |
| assertFalse(%HasHoleyElements(array)); |
| |
| callAndAssertFill(array, "42", ...arguments); |
| }, |
| |
| ARRAY_HOLEY_ELEMENTS(value, from, to) { |
| let array = pristineArray(`["Some string", , {}, , "Another string"]`); |
| assertTrue(%HasObjectElements(array)); |
| assertTrue(%HasHoleyElements(array)); |
| |
| callAndAssertFill(array, "42", ...arguments); |
| }, |
| |
| ARRAY_PACKED_SMI_ELEMENTS(value, from, to) { |
| let array = pristineArray(`[0, -42, 5555, 23, 6]`); |
| assertTrue(%HasSmiElements(array)); |
| assertFalse(%HasHoleyElements(array)); |
| |
| callAndAssertFill(array, 42, ...arguments); |
| }, |
| |
| ARRAY_HOLEY_SMI_ELEMENTS(value, from, to) { |
| let array = pristineArray(`[0, , 5555, , 6]`); |
| assertTrue(%HasSmiElements(array)); |
| assertTrue(%HasHoleyElements(array)); |
| |
| callAndAssertFill(array, 42, ...arguments); |
| }, |
| |
| ARRAY_PACKED_DOUBLE_ELEMENTS(value, from, to) { |
| let array = pristineArray(`[3.14, 7.00001, NaN, -25.3333, 1.0]`); |
| assertTrue(%HasDoubleElements(array)); |
| assertFalse(%HasHoleyElements(array)); |
| |
| callAndAssertFill(array, 42.42, ...arguments); |
| }, |
| |
| ARRAY_HOLEY_DOUBLE_ELEMENTS(value, from, to) { |
| let array = pristineArray(`[3.14, , , , 1.0]`); |
| assertTrue(%HasDoubleElements(array)); |
| assertTrue(%HasHoleyElements(array)); |
| |
| callAndAssertFill(array, 42.42, ...arguments); |
| }, |
| |
| ARRAY_DICTIONARY_ELEMENTS(value, from, to) { |
| let array = pristineArray(`[0, , 2, 3, 4]`); |
| Object.defineProperty(array, 1, { get() { return this.foo; }, |
| set(val) { this.foo = val; }}); |
| assertTrue(%HasDictionaryElements(array)); |
| |
| callAndAssertFill(array, "42", ...arguments); |
| } |
| |
| // TODO(szuend): Add additional tests receivers other than arrays |
| // (Objects, TypedArrays, etc.). |
| }; |
| |
| function RunTest(test) { |
| test(); |
| test(undefined); |
| test(undefined, 1); |
| test(undefined, 1, 4); |
| } |
| |
| function RunTests(tests) { |
| Object.keys(tests).forEach(test => RunTest(tests[test])); |
| } |
| |
| RunTests(tests); |
| |
| Array.prototype.__proto__ = { |
| __proto__: Array.prototype.__proto__ |
| }; |
| |
| RunTests(tests); |