From d842aa21af45b780384586f8a4a82e37df50b5c7 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-configurable property test --- ...et-array-with-non-configurable-property.js | 44 +++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 test/built-ins/Array/prototype/filter/target-array-with-non-configurable-property.js diff --git a/test/built-ins/Array/prototype/filter/target-array-with-non-configurable-property.js b/test/built-ins/Array/prototype/filter/target-array-with-non-configurable-property.js new file mode 100644 index 0000000000..035c325ad6 --- /dev/null +++ b/test/built-ins/Array/prototype/filter/target-array-with-non-configurable-property.js @@ -0,0 +1,44 @@ +// 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's "0" is non-configurable) +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) { + Object.defineProperty(this, "0", { + writable: true, + configurable: false, + }); +}; + +var arr = [1]; +arr.constructor = {}; +arr.constructor[Symbol.species] = A; + +assert.throws(TypeError, function() { + arr.filter(function() { + return true; + }); +});