From 06357bed6a0a86416a982e8fe23648f325550724 Mon Sep 17 00:00:00 2001 From: Alexey Shvayka Date: Sun, 16 Feb 2020 20:54:33 +0200 Subject: [PATCH] Add Array#filter non-extensible test --- .../filter/target-array-non-extensible.js | 42 +++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 test/built-ins/Array/prototype/filter/target-array-non-extensible.js diff --git a/test/built-ins/Array/prototype/filter/target-array-non-extensible.js b/test/built-ins/Array/prototype/filter/target-array-non-extensible.js new file mode 100644 index 0000000000..1555620909 --- /dev/null +++ b/test/built-ins/Array/prototype/filter/target-array-non-extensible.js @@ -0,0 +1,42 @@ +// Copyright (C) 2020 Alexey Shvayka. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. + +/*--- +esid: sec-array.prototype.filter +description: > + TypeError is thrown if CreateDataProperty fails. + (result object is non-extensible) +info: | + Array.prototype.filter ( callbackfn [ , thisArg ] ) + + [...] + 7. Repeat, while k < len + [...] + c. If kPresent is true, then + [...] + iii. If selected is true, then + 1. Perform ? CreateDataPropertyOrThrow(A, ! ToString(to), kValue). + [...] + + CreateDataPropertyOrThrow ( O, P, V ) + + [...] + 3. Let success be ? CreateDataProperty(O, P, V). + 4. If success is false, throw a TypeError exception. +features: [Symbol.species] +---*/ + +var A = function(_length) { + this.length = 0; + Object.preventExtensions(this); +}; + +var arr = [1]; +arr.constructor = {}; +arr.constructor[Symbol.species] = A; + +assert.throws(TypeError, function() { + arr.filter(function() { + return true; + }); +});