Bug 446663. Make sure that if the user is typing in a text input its text input listener will get the events (so that undo/redo work and oninput is fired).

This commit is contained in:
Mats Palmgren 2008-07-31 17:36:21 -07:00
parent 8534784f1c
commit 8bbc56fcbc

View File

@ -0,0 +1,81 @@
<!DOCTYPE HTML>
<html>
<!--
https://bugzilla.mozilla.org/show_bug.cgi?id=446663
-->
<head>
<title>Test for Bug 446663</title>
<script type="text/javascript" src="/MochiKit/MochiKit.js"></script>
<script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
<script type="text/javascript" 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=446663">Mozilla Bug 446663</a>
<p id="display">
<style>#bug446663_a:focus{overflow:hidden}</style>
<input id="bug446663_a"><input id="bug446663_b"></p>
<div id="content" style="display: none">
</div>
<pre id="test">
<script class="testbody" type="text/javascript">
/** Test for Bug 446663 **/
function test_edit_cmds(id) {
netscape.security.PrivilegeManager.enablePrivilege('UniversalXPConnect');
var elm = document.getElementById(id);
elm.select();
elm.controllers.getControllerForCommand('cmd_cut')
.doCommand('cmd_cut');
is(elm.value, '', id + " cut");
elm.controllers.getControllerForCommand('cmd_undo')
.doCommand('cmd_undo');
is(elm.value, '123', id + " undo");
}
var inputHappened = false;
function inputListener() {
inputHappened = true;
$(id).removeEventListener("input", inputListener, false);
}
var id = 'bug446663_a'
var elm = document.getElementById(id);
elm.focus();
var x = document.body.offsetHeight;
$(id).addEventListener("input", inputListener, false);
sendChar('1',elm);
is(inputHappened, true, "How come no input?");
sendChar('3',elm);
sendKey('LEFT',elm)
sendChar('2',elm);
elm.blur();
x = document.body.offsetHeight;
is(elm.value, '123', id + " edit");
test_edit_cmds(id)
id = 'bug446663_b'
elm = document.getElementById(id);
elm.focus();
sendChar('1',elm);
elm.style.display = 'none'
var x = document.body.offsetHeight;
elm.style.display = 'inline'
x = document.body.offsetHeight;
sendChar('3',elm);
sendKey('LEFT',elm)
sendChar('2',elm);
elm.blur();
x = document.body.offsetHeight;
is(elm.value, '123', id + " edit");
test_edit_cmds(id)
</script>
</pre>
</body>
</html>