Support iterable objects in Promise.all and Promise.race functions (#3496)

JerryScript-DCO-1.0-Signed-off-by: Daniel Balla dballa@inf.u-szeged.hu
This commit is contained in:
Daniel Balla
2020-01-10 15:44:52 +01:00
committed by Robert Fancsik
parent c407e8a04c
commit 1725e014b8
7 changed files with 416 additions and 195 deletions
@@ -0,0 +1,76 @@
/* Copyright JS Foundation and other contributors, http://js.foundation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
function createIterable(arr, methods = {}) {
let iterable = function *() {
let idx = 0;
while (idx < arr.length) {
yield arr[idx];
idx++;
}
}();
iterable['return'] = methods['return'];
iterable['throw'] = methods['throw'];
return iterable;
};
// iterator next
Promise.all({[Symbol.iterator]() { return {get next() { throw 5; }}}
}).then(onfullfilled => {
// If this is not called, the promise has failed, and catch must be called.
assert(false);
}).catch(err => {
assert(err === 5);
});
// iterator value
Promise.all({ [Symbol.iterator] () { return { next () { return { get value () { throw 5 }}}}}
}).then(onfullfilled => {
// If this is not called, the promise has failed, and catch must be called.
assert(false);
}).catch(err => {
assert(err === 5);
});
// iterator done
Promise.all({ [Symbol.iterator] () { return { next () { return { get done () { throw 5 }}}}}
}).then(onfullfilled => {
// If this is not called, the promise has failed, and catch must be called.
assert(false);
}).catch(err => {
assert(err === 5);
});
// iterator get
Promise.all({ get [Symbol.iterator] () { throw 5 }
}).then(onfullfilled => {
// If this is not called, the promise has failed, and catch must be called.
assert(false);
}).catch(err => {
assert(err === 5);
});
var fulfills = Promise.all(createIterable([
new Promise(resolve => { resolve("foo"); }),
new Promise(resolve => { resolve("bar"); }),
]));
var rejects = Promise.all(createIterable([
new Promise((_, reject) => { reject("baz"); }),
new Promise((_, reject) => { reject("qux"); }),
]));
fulfills.then(result => { assert (result + "" === "foo,bar"); });
rejects.catch(result => { assert (result === "baz"); });
@@ -0,0 +1,64 @@
/* Copyright JS Foundation and other contributors, http://js.foundation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
function createIterable(arr, methods = {}) {
let iterable = function *() {
let idx = 0;
while (idx < arr.length) {
yield arr[idx];
idx++;
}
}();
iterable['return'] = methods['return'];
iterable['throw'] = methods['throw'];
return iterable;
};
// iterator next
Promise.race({[Symbol.iterator]() { return {get next() { throw 5; }}}
}).catch(err => {
assert(err === 5);
});
// iterator value
Promise.race({ [Symbol.iterator] () { return { next () { return { get value () { throw 5 }}}}}
}).catch(err => {
assert(err === 5);
});
// iterator done
Promise.race({ [Symbol.iterator] () { return { next () { return { get done () { throw 5 }}}}}
}).catch(err => {
assert(err === 5);
});
// iterator get
Promise.race({ get [Symbol.iterator] () { throw 5 }
}).catch(err => {
assert(err === 5);
});
var fulfills = Promise.race(createIterable([
new Promise(resolve => { resolve("foo"); }),
new Promise(resolve => { resolve("bar"); }),
]));
var rejects = Promise.race(createIterable([
new Promise((_, reject) => { reject("baz"); }),
new Promise((_, reject) => { reject("qux"); }),
]));
fulfills.then(result => { assert (result + "" === "foo"); });
rejects.catch(result => { assert (result === "baz"); });
@@ -13,4 +13,8 @@
// limitations under the License.
Object.defineProperty(Array.prototype, 0, { get : function () { throw $; } });
Promise.race([ , this]).then(Error);
var asyncPassed = false;
Promise.race([ , this]).then(Error).catch(function(err) { asyncPassed = (err instanceof ReferenceError); });
new Promise(function() {
throw 5;
}).then(Error).catch(function() { assert(asyncPassed); });