1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
// |reftest| skip-if(!xulRuntime.shell) -- needs getSelfHostedValue and drainJobQueue
if (!this.Promise) {
this.reportCompare && reportCompare(true,true);
quit(0);
}
function onResolved(val) {
result = 'resolved with ' + val;
}
function onRejected(val) {
result = 'rejected with ' + val;
}
// Replacing `Promise#then` shouldn't affect getWaitForAllPromise.
let originalThen = Promise.prototype.then;
Promise.prototype.then = 1;
// Replacing Promise[@@species] shouldn't affect getWaitForAllPromise.
Promise[Symbol.species] = function(){};
// Replacing `Promise` shouldn't affect getWaitForAllPromise.
let PromiseCtor = Promise;
Promise = {};
// Replacing Array[@@iterator] shouldn't affect getWaitForAllPromise.
Array.prototype[Symbol.iterator] = function(){};
let resolveFunctions = [];
let rejectFunctions = [];
let promises = [];
for (let i = 0; i < 3; i++) {
let p = new PromiseCtor(function(res_, rej_) {
resolveFunctions.push(res_);
rejectFunctions.push(rej_);
});
promises.push(p);
}
let allPromise = getWaitForAllPromise(promises);
let then = originalThen.call(allPromise, onResolved, onRejected);
resolveFunctions.forEach((fun, i)=>fun(i));
drainJobQueue();
assertEq(result, 'resolved with 0,1,2');
// Empty lists result in a promise resolved with an empty array.
result = undefined;
originalThen.call(getWaitForAllPromise([]), v=>(result = v));
drainJobQueue();
assertEq(result instanceof Array, true);
assertEq(result.length, 0);
//Empty lists result in a promise resolved with an empty array.
result = undefined;
originalThen.call(getWaitForAllPromise([]), v=>(result = v));
drainJobQueue();
assertEq(result instanceof Array, true);
assertEq(result.length, 0);
this.reportCompare && reportCompare(true,true);
|