2016-06-10 19:12:14 +00:00
|
|
|
// Copyright 2016 the V8 project authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
|
|
// found in the LICENSE file.
|
|
|
|
|
|
|
|
// Flags: --harmony-async-await --expose-debug-as debug --allow-natives-syntax
|
|
|
|
|
2016-09-19 23:51:30 +00:00
|
|
|
// The test observes the callbacks that async/await makes to the inspector
|
2016-09-23 22:23:50 +00:00
|
|
|
// to make accurate stack traces. The pattern is based on saving a stack once
|
|
|
|
// with enqueueRecurring and restoring it multiple times.
|
|
|
|
|
|
|
|
// Additionally, the limited number of events is an indirect indication that
|
|
|
|
// we are not doing extra Promise processing that could be associated with memory
|
|
|
|
// leaks (v8:5380). In particular, no stacks are saved and restored for extra
|
|
|
|
// Promise handling on throwaway Promises.
|
|
|
|
|
2016-09-19 23:51:30 +00:00
|
|
|
// TODO(littledan): Write a test that demonstrates that the memory leak in
|
|
|
|
// the exception case is fixed.
|
|
|
|
|
2016-06-10 19:12:14 +00:00
|
|
|
Debug = debug.Debug;
|
|
|
|
|
|
|
|
var base_id = -1;
|
|
|
|
var exception = null;
|
|
|
|
var expected = [
|
2016-09-23 22:23:50 +00:00
|
|
|
'enqueueRecurring #1',
|
2016-09-19 23:51:30 +00:00
|
|
|
'willHandle #1',
|
|
|
|
'then #1',
|
|
|
|
'didHandle #1',
|
2016-09-23 22:23:50 +00:00
|
|
|
'willHandle #1',
|
2016-09-19 23:51:30 +00:00
|
|
|
'then #2',
|
2016-09-23 22:23:50 +00:00
|
|
|
'cancel #1',
|
|
|
|
'didHandle #1',
|
2016-06-10 19:12:14 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
function assertLog(msg) {
|
|
|
|
print(msg);
|
|
|
|
assertTrue(expected.length > 0);
|
|
|
|
assertEquals(expected.shift(), msg);
|
|
|
|
if (!expected.length) {
|
|
|
|
Debug.setListener(null);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function listener(event, exec_state, event_data, data) {
|
|
|
|
if (event != Debug.DebugEvent.AsyncTaskEvent) return;
|
|
|
|
try {
|
2016-10-14 21:16:46 +00:00
|
|
|
if ("Promise.resolve" == event_data.name()) return;
|
2016-06-10 19:12:14 +00:00
|
|
|
if (base_id < 0)
|
|
|
|
base_id = event_data.id();
|
|
|
|
var id = event_data.id() - base_id + 1;
|
2016-09-23 22:23:50 +00:00
|
|
|
assertTrue("async function" == event_data.name());
|
2016-06-10 19:12:14 +00:00
|
|
|
assertLog(event_data.type() + " #" + id);
|
|
|
|
} catch (e) {
|
|
|
|
print(e + e.stack)
|
|
|
|
exception = e;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Debug.setListener(listener);
|
|
|
|
|
|
|
|
var resolver;
|
|
|
|
var p = new Promise(function(resolve, reject) {
|
|
|
|
resolver = resolve;
|
|
|
|
});
|
|
|
|
|
|
|
|
async function main() {
|
|
|
|
await p;
|
|
|
|
assertLog("then #1");
|
|
|
|
await undefined;
|
|
|
|
assertLog("then #2");
|
|
|
|
}
|
|
|
|
main();
|
|
|
|
resolver();
|
|
|
|
|
|
|
|
%RunMicrotasks();
|
|
|
|
|
|
|
|
assertNull(exception);
|
2016-10-14 21:16:46 +00:00
|
|
|
|
|
|
|
Debug.clearBreakOnUncaughtException();
|
|
|
|
Debug.setListener(null);
|
|
|
|
|
|
|
|
var resolve;
|
|
|
|
var turnOnListenerPromise = new Promise(r => resolve = r);
|
|
|
|
async function confused() {
|
|
|
|
await turnOnListenerPromise;
|
|
|
|
throw foo
|
|
|
|
}
|
|
|
|
|
|
|
|
confused();
|
|
|
|
|
|
|
|
Promise.resolve().then(() => {
|
|
|
|
Debug.setListener(listener);
|
|
|
|
Debug.setBreakOnUncaughtException();
|
|
|
|
resolve();
|
|
|
|
});
|
|
|
|
|
|
|
|
%RunMicrotasks();
|
|
|
|
assertNull(exception);
|