forked from mirrors/gecko-dev
This is split from the previous changeset since if we include dom/ the file size is too large for phabricator to handle. This is an autogenerated commit to handle scripts loading mochitest harness files, in the simple case where the script src is on the same line as the tag. This was generated with https://bug1544322.bmoattachments.org/attachment.cgi?id=9058170 using the `--part 2` argument. Differential Revision: https://phabricator.services.mozilla.com/D27457 --HG-- extra : moz-landing-system : lando
71 lines
2.4 KiB
HTML
71 lines
2.4 KiB
HTML
<!DOCTYPE HTML>
|
|
<html>
|
|
<!--
|
|
https://bugzilla.mozilla.org/show_bug.cgi?id=633058
|
|
-->
|
|
<head>
|
|
<title>Test for Bug 633058</title>
|
|
<script src="/tests/SimpleTest/SimpleTest.js"></script>
|
|
<script src="/tests/SimpleTest/EventUtils.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=633058">Mozilla Bug 633058</a>
|
|
<p id="display"></p>
|
|
<div id="content">
|
|
<input>
|
|
</div>
|
|
<pre id="test">
|
|
<script type="application/javascript">
|
|
|
|
/** Test for Bug 633058 **/
|
|
|
|
SimpleTest.waitForExplicitFinish();
|
|
|
|
const kStrictKeyPressEvents =
|
|
SpecialPowers.getBoolPref("dom.keyboardevent.keypress.dispatch_non_printable_keys_only_system_group_in_content");
|
|
|
|
// Turn off Spatial Navigation so that the 'keypress' event fires in traditional behavior.
|
|
SimpleTest.waitForFocus(function() {
|
|
SpecialPowers.pushPrefEnv({"set":[['snav.enabled', false]]}, startTest);
|
|
});
|
|
function startTest() {
|
|
var nbExpectedKeyDown = 8;
|
|
var nbExpectedKeyPress = kStrictKeyPressEvents ? 1 : 8;
|
|
var inputGotKeyPress = 0;
|
|
var inputGotKeyDown = 0;
|
|
var divGotKeyPress = 0;
|
|
var divGotKeyDown = 0;
|
|
|
|
var input = document.getElementsByTagName('input')[0];
|
|
var content = document.getElementById('content');
|
|
|
|
content.addEventListener("keydown", () => { divGotKeyDown++; });
|
|
content.addEventListener("keypress", () => { divGotKeyPress++; });
|
|
input.addEventListener("keydown", () => { inputGotKeyDown++; });
|
|
input.addEventListener("keypress", () => { inputGotKeyPress++; });
|
|
|
|
input.addEventListener('focus', function() {
|
|
SimpleTest.executeSoon(() => {
|
|
synthesizeKey('KEY_ArrowUp');
|
|
synthesizeKey('KEY_ArrowLeft');
|
|
synthesizeKey('KEY_ArrowRight');
|
|
synthesizeKey('KEY_ArrowDown');
|
|
synthesizeKey('KEY_Backspace');
|
|
synthesizeKey('KEY_Delete');
|
|
synthesizeKey('KEY_Escape');
|
|
synthesizeKey('KEY_Enter'); // Will dispatch keypress event even in strict behavior.
|
|
|
|
is(inputGotKeyDown, nbExpectedKeyDown, "input got all keydown events");
|
|
is(inputGotKeyPress, nbExpectedKeyPress, "input got all keypress events");
|
|
is(divGotKeyDown, nbExpectedKeyDown, "div got all keydown events");
|
|
is(divGotKeyPress, nbExpectedKeyPress, "div got all keypress events");
|
|
SimpleTest.finish();
|
|
});
|
|
}, {once: true});
|
|
input.focus();
|
|
}
|
|
</script>
|
|
</pre>
|
|
</body>
|
|
</html>
|