chromium/third_party/blink/web_tests/external/wpt/content-security-policy/script-src/addInlineTestsWithDOMManipulation.js

(function () {
  var t_spv = async_test("Test that securitypolicyviolation event is fired");
  var test_count = 2;

  window.addEventListener("securitypolicyviolation", t_spv.step_func_done(function(e) {
   assert_equals(e.violatedDirective, "script-src-elem");
   if (--test_count <= 0) {
    t_spv.done();
   }
  }));


  var dmTest = async_test("DOM manipulation inline tests");
  var attachPoint = document.getElementById('attachHere');
  var inlineScript = document.createElement('script');
  var scriptText = document.createTextNode('dmTest.step(function() {assert_unreached("Unsafe inline script ran - createTextNode.")});');

  inlineScript.appendChild(scriptText);
  attachPoint.appendChild(inlineScript);

  document.getElementById('emptyScript').innerHTML = 'dmTest.step(function() {assert_unreached("Unsafe inline script ran - innerHTML.")});';
  document.getElementById('emptyDiv').outerHTML = '<script id=outerHTMLScript>dmTest.step(function() {assert_unreached("Unsafe inline script ran - outerHTML.")});</script>';

  document.write('<script>dmTest.step(function() {assert_unreached("Unsafe inline script ran - document.write")});</script>');
  document.writeln('<script>dmTest.step(function() {assert_unreached("Unsafe inline script ran - document.writeln")});</script>');

  dmTest.done();
})();