Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(119)

Side by Side Diff: test/mjsunit/harmony/async-await-basic.js

Issue 2091313002: [parser] don't report error for CoverInitializedNames in async arrow formals (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: _Really_ fix compile error Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « test/cctest/test-parsing.cc ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2016 the V8 project authors. All rights reserved. 1 // Copyright 2016 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 // Flags: --harmony-async-await --allow-natives-syntax 5 // Flags: --harmony-async-await --allow-natives-syntax
6 6
7 // Do not install `AsyncFunction` constructor on global object 7 // Do not install `AsyncFunction` constructor on global object
8 8
9 function assertThrowsAsync(run, errorType, message) { 9 function assertThrowsAsync(run, errorType, message) {
10 var actual; 10 var actual;
(...skipping 325 matching lines...) Expand 10 before | Expand all | Expand 10 after
336 log = []; 336 log = [];
337 assertEqualsAsync(6, () => resumeAfterThrowNewEval(5)); 337 assertEqualsAsync(6, () => resumeAfterThrowNewEval(5));
338 assertEquals("start:5 resume:throw1 resume:throw2", log.join(" ")); 338 assertEquals("start:5 resume:throw1 resume:throw2", log.join(" "));
339 339
340 async function foo() {} 340 async function foo() {}
341 assertEquals("async function foo() {}", foo.toString()); 341 assertEquals("async function foo() {}", foo.toString());
342 assertEquals("async function () {}", async function() {}.toString()); 342 assertEquals("async function () {}", async function() {}.toString());
343 assertEquals("async x => x", (async x => x).toString()); 343 assertEquals("async x => x", (async x => x).toString());
344 assertEquals("async x => { return x }", (async x => { return x }).toString()); 344 assertEquals("async x => { return x }", (async x => { return x }).toString());
345 class AsyncMethod { async foo() { } } 345 class AsyncMethod { async foo() { } }
346 assertEquals("async foo() { }", Function.prototype.toString.call(AsyncMethod.pro totype.foo)); 346 assertEquals("async foo() { }",
347 assertEquals("async foo() { }", Function.prototype.toString.call({async foo() { }}.foo)); 347 Function.prototype.toString.call(AsyncMethod.prototype.foo));
348 assertEquals("async foo() { }",
349 Function.prototype.toString.call({async foo() { }}.foo));
348 350
349 // Async functions are not constructible 351 // Async functions are not constructible
350 assertThrows(() => class extends (async function() {}) {}, TypeError); 352 assertThrows(() => class extends (async function() {}) {}, TypeError);
353
354 // Regress v8:5148
355 assertEqualsAsync("1", () => (async({ a = NaN }) => a)({ a: "1" }));
356 assertEqualsAsync(
357 "10", () => (async(foo, { a = NaN }) => foo + a)("1", { a: "0" }));
358 assertEqualsAsync("2", () => (async({ a = "2" }) => a)({ a: undefined }));
359 assertEqualsAsync(
360 "20", () => (async(foo, { a = "0" }) => foo + a)("2", { a: undefined }));
361 assertThrows(() => eval("async({ foo = 1 })"), SyntaxError);
362 assertThrows(() => eval("async(a, { foo = 1 })"), SyntaxError);
OLDNEW
« no previous file with comments | « test/cctest/test-parsing.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698