diff options
Diffstat (limited to 'js/src/tests/test262/built-ins/Promise/allSettled/resolve-element-function-name.js')
-rw-r--r-- | js/src/tests/test262/built-ins/Promise/allSettled/resolve-element-function-name.js | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/js/src/tests/test262/built-ins/Promise/allSettled/resolve-element-function-name.js b/js/src/tests/test262/built-ins/Promise/allSettled/resolve-element-function-name.js new file mode 100644 index 0000000000..eb6a7d1ddc --- /dev/null +++ b/js/src/tests/test262/built-ins/Promise/allSettled/resolve-element-function-name.js @@ -0,0 +1,41 @@ +// Copyright (C) 2019 Leo Balter. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. + +/*--- +esid: sec-promise.allsettled-resolve-element-functions +description: The `name` property of Promise.allSettled Resolve Element functions +info: | + A promise resolve function is an anonymous built-in function. + + 17 ECMAScript Standard Built-in Objects: + Every built-in function object, including constructors, has a `name` + property whose value is a String. Functions that are identified as + anonymous functions use the empty string as the value of the `name` + property. + Unless otherwise specified, the `name` property of a built-in function + object has the attributes { [[Writable]]: *false*, [[Enumerable]]: *false*, + [[Configurable]]: *true* }. +includes: [propertyHelper.js] +features: [Promise.allSettled] +---*/ + +var resolveElementFunction; +var thenable = { + then(fulfill) { + resolveElementFunction = fulfill; + } +}; + +function NotPromise(executor) { + executor(function() {}, function() {}); +} +NotPromise.resolve = function(v) { + return v; +}; +Promise.allSettled.call(NotPromise, [thenable]); + +verifyProperty(resolveElementFunction, "name", { + value: "", writable: false, enumerable: false, configurable: true +}); + +reportCompare(0, 0); |