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

Side by Side Diff: test/inspector/debugger/caught-exception-from-framework-inside-async.js

Issue 2891213002: [inspector] Refactor protocol-test.js (Closed)
Patch Set: comments addressed Created 3 years, 7 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
OLDNEW
1 // Copyright 2017 the V8 project authors. All rights reserved. 1 // Copyright 2017 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 InspectorTest.log('Async caught exception prediction and blackboxing.'); 5 let {session, contextGroup, Protocol} = InspectorTest.start('Async caught except ion prediction and blackboxing.');
6 6
7 InspectorTest.addScript(` 7 contextGroup.addScript(`
8 function constructorThrow() { 8 function constructorThrow() {
9 return new Promise((resolve, reject) => 9 return new Promise((resolve, reject) =>
10 Promise.resolve().then(() => 10 Promise.resolve().then(() =>
11 reject("f") // Exception f 11 reject("f") // Exception f
12 ) 12 )
13 ); 13 );
14 } 14 }
15 15
16 function dotCatch(producer) { 16 function dotCatch(producer) {
17 Promise.resolve(producer()).catch(() => {}); 17 Promise.resolve(producer()).catch(() => {});
18 } 18 }
19 //# sourceURL=framework.js`); 19 //# sourceURL=framework.js`);
20 20
21 InspectorTest.setupScriptMap(); 21 session.setupScriptMap();
22 (async function test() { 22 (async function test() {
23 Protocol.Debugger.enable(); 23 Protocol.Debugger.enable();
24 Protocol.Debugger.setBlackboxPatterns({patterns: ['framework\.js']}); 24 Protocol.Debugger.setBlackboxPatterns({patterns: ['framework\.js']});
25 Protocol.Debugger.setPauseOnExceptions({state: 'all'}); 25 Protocol.Debugger.setPauseOnExceptions({state: 'all'});
26 Protocol.Runtime.evaluate({expression: 'dotCatch(constructorThrow);'}); 26 Protocol.Runtime.evaluate({expression: 'dotCatch(constructorThrow);'});
27 // Should break at this debugger statement, not at reject. 27 // Should break at this debugger statement, not at reject.
28 Protocol.Runtime.evaluate({expression: 'setTimeout(\'debugger;\', 0);'}); 28 Protocol.Runtime.evaluate({expression: 'setTimeout(\'debugger;\', 0);'});
29 await waitPauseAndDumpLocation(); 29 await waitPauseAndDumpLocation();
30 InspectorTest.completeTest(); 30 InspectorTest.completeTest();
31 })(); 31 })();
32 32
33 async function waitPauseAndDumpLocation() { 33 async function waitPauseAndDumpLocation() {
34 var message = await Protocol.Debugger.oncePaused(); 34 var message = await Protocol.Debugger.oncePaused();
35 InspectorTest.log('paused at:'); 35 InspectorTest.log('paused at:');
36 InspectorTest.logSourceLocation(message.params.callFrames[0].location); 36 session.logSourceLocation(message.params.callFrames[0].location);
37 return message; 37 return message;
38 } 38 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698