| <!DOCTYPE html> |
| <html> |
| <head> |
| <title>Removing an async script before execution</title> |
| <meta http-equiv="content-type" content="text/html; charset=UTF-8" /> |
| <meta description="This test ensures that an async script still executes if it is removed from a markup before the download is complete. The other two scripts that come after it in insertion order should execute as well." /> |
| <link rel="author" title="Microsoft" href="http://www.microsoft.com/" /> |
| <link rel="help" href="https://html.spec.whatwg.org/multipage/#execute-the-script-block"/> |
| <script src="/resources/testharness.js"></script> |
| <script src="/resources/testharnessreport.js"></script> |
| <script type="text/javascript"> |
| var t = async_test("Removing an async script before execution"); |
| |
| function timeout() |
| { |
| t.step(function(){ assert_equals(document.getElementById("testresult").innerHTML, "4123")}); |
| t.done(); |
| } |
| |
| var timer = setTimeout(timeout, 8000); |
| |
| function log(text) |
| { |
| var textNode = document.createTextNode(text); |
| document.getElementById("testresult").appendChild(textNode); |
| } |
| </script> |
| </head> |
| <body> |
| <div id=log></div> |
| <span id="testresult"></span> |
| <script type="text/javascript"> |
| var s1 = document.createElement("script"); |
| s1.src="log.py?sec=2&id=1"; |
| s1.async = false; |
| document.body.appendChild(s1); |
| |
| var s2 = document.createElement("script"); |
| s2.src="log.py?sec=1&id=2"; |
| s2.async = false; |
| document.body.appendChild(s2); |
| |
| var s3 = document.createElement("script"); |
| s3.id = "s3"; |
| s3.src="log.py?sec=0&id=3"; |
| s3.async = false; |
| document.body.appendChild(s3); |
| |
| //Remove s1 (Should still execute) |
| document.body.removeChild(s1); |
| </script> |
| <script type="text/javascript">log('4');</script> |
| </body> |
| </html> |