| (async function(testRunner) { |
| var {page, session, dp} = await testRunner.startBlank('Tests that stepping over caught exception does not pause.'); |
| |
| dp.Debugger.enable(); |
| dp.Runtime.enable(); |
| dp.Runtime.evaluate({expression: ` |
| |
| |
| |
| |
| |
| function testFunction() { |
| function foo() { |
| try { |
| throw new Error(); |
| } catch (e) { |
| } |
| } |
| debugger; |
| foo(); |
| console.log('completed'); |
| } |
| setTimeout(testFunction, 0); |
| `}); |
| |
| function printCallFrames(messageObject) { |
| var callFrames = messageObject.params.callFrames; |
| for (var callFrame of callFrames) |
| testRunner.log(callFrame.functionName + ':' + callFrame.location.lineNumber); |
| } |
| |
| printCallFrames(await dp.Debugger.oncePaused()); |
| dp.Debugger.stepOver(); |
| await dp.Debugger.oncePaused(); |
| dp.Debugger.stepOver(); |
| printCallFrames(await dp.Debugger.oncePaused()); |
| dp.Debugger.resume(); |
| await dp.Runtime.onceConsoleAPICalled(messageObject => messageObject.params.args[0].value === 'completed'); |
| |
| dp.Runtime.evaluate({expression: 'setTimeout(testFunction, 0);'} ); |
| printCallFrames(await dp.Debugger.oncePaused()); |
| dp.Debugger.stepOver(); |
| await dp.Debugger.oncePaused(); |
| dp.Debugger.stepInto(); |
| await dp.Debugger.oncePaused(); |
| dp.Debugger.stepOver(); |
| await dp.Debugger.oncePaused(); |
| dp.Debugger.stepOver(); |
| printCallFrames(await dp.Debugger.oncePaused()); |
| dp.Debugger.resume(); |
| await dp.Runtime.onceConsoleAPICalled(messageObject => messageObject.params.args[0].value === 'completed'); |
| |
| testRunner.completeTest(); |
| }) |