| <body> |
| <p>Test Worker.terminate().</p> |
| <div id=result></div> |
| <script src="../../resources/gc.js"></script> |
| <script> |
| function log(message) |
| { |
| document.getElementById("result").innerHTML += message + "<br>"; |
| } |
| |
| if (window.testRunner) { |
| testRunner.dumpAsText(); |
| testRunner.waitUntilDone(); |
| // Disable console messages because console errors about worker script |
| // fetching can be printed depending on timing of worker termination and |
| // that confuses the test expectations. |
| testRunner.setDumpConsoleMessages(false); |
| } |
| |
| var worker = new Worker('resources/worker-common.js'); |
| worker.terminate(); |
| |
| var worker2 = new Worker('resources/worker-common.js'); |
| worker2.terminate(); |
| worker2 = 0; |
| gc(); |
| |
| var worker3 = new Worker('resources/worker-common.js'); |
| worker3.onmessage = function(evt) { |
| log("FAIL"); |
| } |
| worker3.postMessage("eval true"); |
| worker3.terminate(); |
| |
| var worker4 = new Worker('resources/worker-common.js'); |
| worker4.onmessage = function(evt) { |
| worker4.onmessage = function() { log("FAIL"); } |
| worker4.postMessage("eval true"); |
| worker4.terminate(); |
| log("Received message from worker4."); |
| setTimeout("log('DONE'); if (window.testRunner) testRunner.notifyDone()", 1000); |
| } |
| worker4.postMessage("eval true"); |
| |
| </script> |
| </body> |
| </html> |