mirror of
https://github.com/servo/servo.git
synced 2025-06-26 18:14:34 +01:00
Update web-platform-tests to revision e9e85e67994df01673a8eb55c47d1b6f5eb6c18a
This commit is contained in:
parent
078b816959
commit
ad8638dd6e
70 changed files with 289 additions and 170 deletions
|
@ -0,0 +1,40 @@
|
|||
// META: global=dedicatedworker,sharedworker
|
||||
|
||||
// The `then` handlers for `Promise.resolve()` are evaluated in the first
|
||||
// microtasks checkpoint after `Promise.resolve()`.
|
||||
|
||||
// ----------------------------------------------------------------
|
||||
// Check when microtasks checkpoint is performed around importScripts().
|
||||
|
||||
// The expectation is: the `then` handlers are evaluated after the script
|
||||
// calling importScripts() is finished, not immediately after importScripts().
|
||||
// Although #clean-up-after-running-script is executed as a part of
|
||||
// #run-a-classic-script for importScripts()ed scripts, but at that time
|
||||
// microtasks checkpoint is NOT performed because JavaScript execution context
|
||||
// stack is not empty.
|
||||
|
||||
self.log = [];
|
||||
|
||||
// Microtasks should be executed before
|
||||
// #run-a-classic-script/#run-a-module-script is completed, and thus before
|
||||
// script evaluation scheduled by setTimeout().
|
||||
async_test(t => {
|
||||
self.addEventListener('error',
|
||||
t.unreached_func('error event should not be fired'));
|
||||
|
||||
t.step_timeout(() => {
|
||||
assert_array_equals(log, [
|
||||
'importScripts()ed script',
|
||||
'catch',
|
||||
'promise'
|
||||
]);
|
||||
t.done();
|
||||
},
|
||||
0);
|
||||
}, "Promise resolved during importScripts()");
|
||||
|
||||
try {
|
||||
importScripts('resources/resolve-then-throw.js');
|
||||
} catch (e) {
|
||||
self.log.push('catch');
|
||||
}
|
|
@ -0,0 +1,3 @@
|
|||
self.log.push('importScripts()ed script');
|
||||
Promise.resolve().then(() => self.log.push('promise'));
|
||||
throw new Error('foo');
|
Loading…
Add table
Add a link
Reference in a new issue