editor/libeditor/tests/test_keypress_untrusted_event.html
author Markus Stange <mstange@themasta.com>
Mon, 15 Jun 2015 19:20:59 -0400
changeset 249905 3f025568ad349d7b4a4da45feef6812c4e4d4101
parent 200218 a357afff88300587c1905f01819c777f461af7eb
child 329664 7b434711753b98a87603453caaa0945791ffe12b
permissions -rw-r--r--
Bug 1165185 - Try to avoid invalidations when scrolling transformed elements. r=roc

<!DOCTYPE HTML>
<html>
<!--
https://bugzilla.mozilla.org/show_bug.cgi?id=622245
-->
<head>
  <title>Test for untrusted keypress events</title>
  <script type="application/javascript" src="/MochiKit/packed.js"></script>
  <script type="application/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
  <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
</head>
<body>
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=622245">Mozilla Bug 622245</a>
<p id="display"></p>
<div id="content">
<input id="i"><br>
<textarea id="t"></textarea><br>
<div id="d" contenteditable style="min-height: 1em;"></div>
</div>
<pre id="test">
<script type="application/javascript">

/** Test for Bug 674770 **/
SimpleTest.waitForExplicitFinish();

var input = document.getElementById("i");
var textarea = document.getElementById("t");
var div = document.getElementById("d");

addLoadEvent(function() {
  input.focus();

  SimpleTest.executeSoon(function() {
    input.addEventListener("keypress",
      function(aEvent) {
        input.removeEventListener("keypress", arguments.callee, false);
        is(aEvent.target, input,
           "The keypress event target isn't the input element");

        SimpleTest.executeSoon(function() {
          is(input.value, "",
             "Did keypress event cause modifying the input element?");
          textarea.focus();
          SimpleTest.executeSoon(runTextareaTest);
        });
      }, false);
    var keypress = document.createEvent("KeyboardEvent");
    keypress.initKeyEvent("keypress", true, true, document.defaultView,
                          false, false, false, false, 0, "a".charCodeAt(0));
    input.dispatchEvent(keypress);
  });
});

function runTextareaTest()
{
  textarea.addEventListener("keypress",
    function(aEvent) {
      textarea.removeEventListener("keypress", arguments.callee, false);
      is(aEvent.target, textarea,
         "The keypress event target isn't the textarea element");

      SimpleTest.executeSoon(function() {
        is(textarea.value, "",
           "Did keypress event cause modifying the textarea element?");
        div.focus();
        SimpleTest.executeSoon(runContentediableTest);
      });
    }, false);
  var keypress = document.createEvent("KeyboardEvent");
  keypress.initKeyEvent("keypress", true, true, document.defaultView,
                        false, false, false, false, 0, "b".charCodeAt(0));
  textarea.dispatchEvent(keypress);
}

function runContentediableTest()
{
  div.addEventListener("keypress",
    function(aEvent) {
      div.removeEventListener("keypress", arguments.callee, false);
      is(aEvent.target, div,
         "The keypress event target isn't the div element");

      SimpleTest.executeSoon(function() {
        is(div.innerHTML, "",
           "Did keypress event cause modifying the div element?");

        SimpleTest.finish();
      });
    }, false);
  var keypress = document.createEvent("KeyboardEvent");
  keypress.initKeyEvent("keypress", true, true, document.defaultView,
                        false, false, false, false, 0, "c".charCodeAt(0));
  div.dispatchEvent(keypress);
}

</script>
</pre>
</body>
</html>