diff options
Diffstat (limited to 'js/src/tests/non262/async-functions/syntax-modules.js')
-rw-r--r-- | js/src/tests/non262/async-functions/syntax-modules.js | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/js/src/tests/non262/async-functions/syntax-modules.js b/js/src/tests/non262/async-functions/syntax-modules.js new file mode 100644 index 0000000000..975e19b59a --- /dev/null +++ b/js/src/tests/non262/async-functions/syntax-modules.js @@ -0,0 +1,31 @@ +var BUGNUMBER = 1185106; +var summary = "async/await syntax in module"; + +print(BUGNUMBER + ": " + summary); + +if (typeof parseModule === "function") { + parseModule("async function f() { await 3; }"); + parseModule("async function f() { await 3; }"); + assertThrowsInstanceOf(() => parseModule("var await = 5;"), SyntaxError); + assertThrowsInstanceOf(() => parseModule("await;"), SyntaxError); + assertThrowsInstanceOf(() => parseModule("await 5;"), SyntaxError); + assertThrowsInstanceOf(() => parseModule("function f() { await 5; }"), SyntaxError); + assertThrowsInstanceOf(() => parseModule("() => { await 5; }"), SyntaxError); + assertThrowsInstanceOf(() => parseModule("export var await;"), SyntaxError); + assertThrowsInstanceOf(() => parseModule("await => 1;"), SyntaxError); + assertThrowsInstanceOf(() => parseModule("async function f() { function g() { await 3; } }"), SyntaxError); + + if (typeof Reflect !== "undefined" && Reflect.parse) { + Reflect.parse("export async function f() {}", { target: "module" }); + assertThrowsInstanceOf(() => Reflect.parse("export async function() {}", { target: "module" }), SyntaxError); + + Reflect.parse("export default async function() {}", { target: "module" }); + Reflect.parse("export default async function f() {}", { target: "module" }); + + assertThrowsInstanceOf(() => Reflect.parse("export default async function() { yield; }", { target: "module" }), SyntaxError); + assertThrowsInstanceOf(() => Reflect.parse("export default async function() { yield = 1; }", { target: "module" }), SyntaxError); + } +} + +if (typeof reportCompare === "function") + reportCompare(true, true); |