summaryrefslogtreecommitdiffstats
path: root/dom/html/test/test_bug633058.html
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
commit26a029d407be480d791972afb5975cf62c9360a6 (patch)
treef435a8308119effd964b339f76abb83a57c29483 /dom/html/test/test_bug633058.html
parentInitial commit. (diff)
downloadfirefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz
firefox-26a029d407be480d791972afb5975cf62c9360a6.zip
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/html/test/test_bug633058.html')
-rw-r--r--dom/html/test/test_bug633058.html66
1 files changed, 66 insertions, 0 deletions
diff --git a/dom/html/test/test_bug633058.html b/dom/html/test/test_bug633058.html
new file mode 100644
index 0000000000..a92f1f9369
--- /dev/null
+++ b/dom/html/test/test_bug633058.html
@@ -0,0 +1,66 @@
+<!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();
+
+SimpleTest.waitForFocus(startTest);
+
+function startTest() {
+ var nbExpectedKeyDown = 8;
+ var nbExpectedKeyPress = 1;
+ 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>