From 094ddc7f75edf01db1410f2c711140c6f06e2d79 Mon Sep 17 00:00:00 2001 From: chicoxyzzy Date: Thu, 28 Nov 2019 00:04:46 +0300 Subject: [PATCH] add species-get-error test --- .../Promise/any/species-get-error.js | 29 +++++++++++++++++++ 1 file changed, 29 insertions(+) create mode 100644 test/built-ins/Promise/any/species-get-error.js diff --git a/test/built-ins/Promise/any/species-get-error.js b/test/built-ins/Promise/any/species-get-error.js new file mode 100644 index 0000000000..1957172c48 --- /dev/null +++ b/test/built-ins/Promise/any/species-get-error.js @@ -0,0 +1,29 @@ +// Copyright (C) 2019 Sergey Rubanov. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. + +/*--- +description: > + Promise.any() does not retrieve `Symbol.species` property of the `this` value +esid: sec-promise.any +info: | + 1. Let C be the this value. + 2. If Type(C) is not Object, throw a TypeError exception. + 3. Let promiseCapability be ? NewPromiseCapability(C). + ... +features: [Promise.any, Symbol.species] +---*/ + +function C(executor) { + executor(function() {}, function() {}); +} +Object.defineProperty(C, Symbol.species, { + get() { + throw new Test262Error('Getter for Symbol.species called'); + } +}); + +C.resolve = function() { + throw new Test262Error(); +}; + +Promise.any.call(C, []);