| OLD | NEW |
| (Empty) |
| 1 <html> | |
| 2 <head> | |
| 3 <script type="text/javascript" src="../../http/tests/inspector-protocol/inspecto
r-protocol-test.js"></script> | |
| 4 <script> | |
| 5 | |
| 6 var worker1; | |
| 7 var worker2; | |
| 8 | |
| 9 function startWorkers() | |
| 10 { | |
| 11 worker1 = new Worker("resources/worker-with-throw.js"); | |
| 12 worker1.onerror = function(e) { | |
| 13 e.preventDefault(); | |
| 14 worker1.terminate(); | |
| 15 } | |
| 16 worker2 = new Worker("resources/worker-with-throw.js"); | |
| 17 } | |
| 18 | |
| 19 function test() | |
| 20 { | |
| 21 InspectorTest.sendCommandOrDie("Target.setAutoAttach", {autoAttach: true, wa
itForDebuggerOnStart: false}, didEnableWorkerDebugging); | |
| 22 | |
| 23 function didEnableWorkerDebugging(event) | |
| 24 { | |
| 25 InspectorTest.sendCommandOrDie("Runtime.evaluate", { expression: "startW
orkers()" }); | |
| 26 } | |
| 27 | |
| 28 var workerRequestId = 1; | |
| 29 function sendCommandToWorker(method, params, workerId) | |
| 30 { | |
| 31 InspectorTest.sendCommand("Target.sendMessageToTarget", | |
| 32 { | |
| 33 "targetId": workerId, | |
| 34 "message": JSON.stringify({ "method": method, | |
| 35 "params": params, | |
| 36 "id": workerRequestId++ }) | |
| 37 }); | |
| 38 } | |
| 39 | |
| 40 var waitForWorkers = 2; | |
| 41 InspectorTest.eventHandler["Target.attachedToTarget"] = function(messageObje
ct) | |
| 42 { | |
| 43 var workerId = messageObject["params"]["targetInfo"]["targetId"]; | |
| 44 InspectorTest.log("Worker created"); | |
| 45 sendCommandToWorker("Runtime.enable", {}, workerId); | |
| 46 if (!--waitForWorkers) | |
| 47 InspectorTest.sendCommandOrDie("Runtime.evaluate", { expression: "wo
rker1.postMessage(239);worker2.postMessage(42);" }); | |
| 48 } | |
| 49 | |
| 50 var workerTerminated = false; | |
| 51 var messageReceived = false; | |
| 52 InspectorTest.eventHandler["Target.receivedMessageFromTarget"] = function(me
ssageObject) | |
| 53 { | |
| 54 var message = JSON.parse(messageObject["params"]["message"]); | |
| 55 if (message["method"] === "Runtime.exceptionThrown") { | |
| 56 var callFrames = message.params.exceptionDetails.stackTrace ? messag
e.params.exceptionDetails.stackTrace.callFrames : []; | |
| 57 InspectorTest.log(callFrames.length > 0 ? "Message with stack trace
received." : "[FAIL] Message contains empty stack trace"); | |
| 58 messageReceived = true; | |
| 59 if (messageReceived && workerTerminated) | |
| 60 InspectorTest.completeTest(); | |
| 61 } | |
| 62 } | |
| 63 | |
| 64 InspectorTest.eventHandler["Target.detachedFromTarget"] = function(messageOb
ject) | |
| 65 { | |
| 66 InspectorTest.eventHandler["Target.detachedFromTarget"] = undefined; | |
| 67 workerTerminated = true; | |
| 68 if (messageReceived && workerTerminated) | |
| 69 InspectorTest.completeTest(); | |
| 70 } | |
| 71 } | |
| 72 </script> | |
| 73 </head> | |
| 74 <body onload="runTest()">Tests that console message from worker contains stack t
race.</body> | |
| 75 </html> | |
| OLD | NEW |