Make asynchronous test configuration explicit
For asynchronous tests, the contract between test file and test runner is implicit: runners are expected to inspect the source code for references to a global `$DONE` identifier. Promote a more explicit contract between test file and test runner by introducing a new frontmatter "tag", `async`. This brings asynchronous test configuration in-line with other configuration mechanisms and also provides a more natural means of test filtering. The modifications to test files was made programatically using the `grep` and `sed` utilities: $ grep "\$DONE" test/ -r --files-with-match --null | \ xargs -0 sed -i 's/^\(flags:\s*\)\[/\1[async, /g' $ grep "\$DONE" test/ -rl --null | \ xargs -0 grep -E '^flags:' --files-without-match --null | \ xargs -0 sed -i 's/^---\*\//flags: [async]\n---*\//'
Showing
- test/built-ins/Promise/all/does-not-invoke-array-setters.js 1 addition, 0 deletionstest/built-ins/Promise/all/does-not-invoke-array-setters.js
- test/built-ins/Promise/all/invoke-resolve-get-error.js 1 addition, 0 deletionstest/built-ins/Promise/all/invoke-resolve-get-error.js
- test/built-ins/Promise/all/invoke-then-error.js 1 addition, 0 deletionstest/built-ins/Promise/all/invoke-then-error.js
- test/built-ins/Promise/all/iter-next-val-err.js 1 addition, 0 deletionstest/built-ins/Promise/all/iter-next-val-err.js
- test/built-ins/Promise/all/iter-step-err.js 1 addition, 0 deletionstest/built-ins/Promise/all/iter-step-err.js
- test/built-ins/Promise/all/reject-deferred.js 1 addition, 0 deletionstest/built-ins/Promise/all/reject-deferred.js
- test/built-ins/Promise/all/reject-ignored-deferred.js 1 addition, 0 deletionstest/built-ins/Promise/all/reject-ignored-deferred.js
- test/built-ins/Promise/all/reject-ignored-immed.js 1 addition, 0 deletionstest/built-ins/Promise/all/reject-ignored-immed.js
- test/built-ins/Promise/all/reject-immed.js 1 addition, 0 deletionstest/built-ins/Promise/all/reject-immed.js
- test/built-ins/Promise/all/resolve-non-thenable.js 1 addition, 0 deletionstest/built-ins/Promise/all/resolve-non-thenable.js
- test/built-ins/Promise/all/resolve-poisoned-then.js 1 addition, 0 deletionstest/built-ins/Promise/all/resolve-poisoned-then.js
- test/built-ins/Promise/all/resolve-thenable.js 1 addition, 0 deletionstest/built-ins/Promise/all/resolve-thenable.js
- test/built-ins/Promise/exception-after-resolve-in-executor.js 1 addition, 0 deletions.../built-ins/Promise/exception-after-resolve-in-executor.js
- test/built-ins/Promise/exception-after-resolve-in-thenable-job.js 1 addition, 0 deletions...lt-ins/Promise/exception-after-resolve-in-thenable-job.js
- test/built-ins/Promise/prototype/catch/S25.4.5.1_A3.1_T1.js 1 addition, 0 deletionstest/built-ins/Promise/prototype/catch/S25.4.5.1_A3.1_T1.js
- test/built-ins/Promise/prototype/catch/S25.4.5.1_A3.1_T2.js 1 addition, 0 deletionstest/built-ins/Promise/prototype/catch/S25.4.5.1_A3.1_T2.js
- test/built-ins/Promise/prototype/then/S25.4.4_A1.1_T1.js 1 addition, 0 deletionstest/built-ins/Promise/prototype/then/S25.4.4_A1.1_T1.js
- test/built-ins/Promise/prototype/then/S25.4.4_A2.1_T1.js 1 addition, 0 deletionstest/built-ins/Promise/prototype/then/S25.4.4_A2.1_T1.js
- test/built-ins/Promise/prototype/then/S25.4.4_A2.1_T2.js 1 addition, 0 deletionstest/built-ins/Promise/prototype/then/S25.4.4_A2.1_T2.js
- test/built-ins/Promise/prototype/then/S25.4.4_A2.1_T3.js 1 addition, 0 deletionstest/built-ins/Promise/prototype/then/S25.4.4_A2.1_T3.js
Loading
Please register or sign in to comment