summaryrefslogtreecommitdiffstats
path: root/js/src/tests/test262/built-ins/Promise/allSettled/new-reject-function.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/src/tests/test262/built-ins/Promise/allSettled/new-reject-function.js')
-rw-r--r--js/src/tests/test262/built-ins/Promise/allSettled/new-reject-function.js50
1 files changed, 50 insertions, 0 deletions
diff --git a/js/src/tests/test262/built-ins/Promise/allSettled/new-reject-function.js b/js/src/tests/test262/built-ins/Promise/allSettled/new-reject-function.js
new file mode 100644
index 0000000000..16e4ed0e2d
--- /dev/null
+++ b/js/src/tests/test262/built-ins/Promise/allSettled/new-reject-function.js
@@ -0,0 +1,50 @@
+// Copyright (C) 2019 Leo Balter. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-performpromiseallsettled
+description: >
+ Each Promise.allSettled element is called with a new Promise.allSettled Reject Element function.
+info: |
+ Runtime Semantics: PerformPromiseAllSettled ( iteratorRecord, constructor, resultCapability )
+
+ ...
+ z. Perform ? Invoke(nextPromise, "then", « resolveElement, rejectElement »).
+ ...
+features: [Promise.allSettled]
+---*/
+
+function rejectFunction() {}
+
+function Constructor(executor) {
+ executor(rejectFunction, Test262Error.thrower);
+}
+Constructor.resolve = function(v) {
+ return v;
+};
+
+var callCount1 = 0,
+ callCount2 = 0;
+var p1OnRejected;
+
+var p1 = {
+ then(_, onRejected) {
+ callCount1 += 1;
+ p1OnRejected = onRejected;
+ assert.notSameValue(onRejected, rejectFunction, 'p1.then');
+ }
+};
+var p2 = {
+ then(_, onRejected) {
+ callCount2 += 1;
+ assert.notSameValue(onRejected, rejectFunction, 'p2.then');
+ assert.notSameValue(onRejected, p1OnRejected, 'p1.onRejected != p2.onRejected');
+ }
+};
+
+Promise.allSettled.call(Constructor, [p1, p2]);
+
+assert.sameValue(callCount1, 1, 'p1.then call count');
+assert.sameValue(callCount2, 1, 'p2.then call count');
+
+reportCompare(0, 0);