4 <meta name="viewport" content="width=device-width">
5 <script src="../../../resources/ui-helper.js"></script>
7 if (window.testRunner) {
8 testRunner.dumpAsText();
9 testRunner.waitUntilDone();
13 <body onkeydown="handleKeyDown(event)" onkeyup="handleKeyUp(event)">
14 <p>This tests that DOM keydown and keyup events are dispatched to a non-editable <body> on iOS for hardware key presses of non-special keys. To run this test manually, verify that two messages are emitted when you press the following keys: <kbd>a</kbd>, <kbd>b</kbd>, <kbd>c</kbd>, <kbd>d</kbd>, <kbd>e</kbd>, <kbd>f</kbd>, <kbd>g</kbd>, <kbd>h</kbd>, <kbd>i</kbd>, <kbd>j</kbd>, <kbd>k</kbd>, <kbd>l</kbd>, <kbd>m</kbd>, <kbd>n</kbd>, <kbd>o</kbd>, <kbd>p</kbd>, <kbd>q</kbd>, <kbd>r</kbd>, <kbd>s</kbd>, <kbd>t</kbd>, <kbd>u</kbd>, <kbd>v</kbd>, <kbd>w</kbd>, <kbd>x</kbd>, <kbd>y</kbd>, <kbd>z</kbd>, <kbd>0</kbd>, <kbd>1</kbd>, <kbd>2</kbd>, <kbd>3</kbd>, <kbd>4</kbd>, <kbd>5</kbd>, <kbd>6</kbd>, <kbd>7</kbd>, <kbd>8</kbd>, <kbd>9</kbd>, <kbd>-</kbd>, <kbd>=</kbd>, <kbd>[</kbd>, <kbd>]</kbd>, <kbd>\</kbd>, <kbd>;</kbd>, <kbd>'</kbd>, <kbd>,</kbd>, <kbd>.</kbd>, <kbd>/</kbd>.</p>
15 <pre id="console"></pre>
17 const asciiCharacters = "abcdefghijklmnopqrstuvwxyz0123456789-=[]\\;',./".split("");
18 var remainingKeysToPress = asciiCharacters;
20 async function nextKeyPress()
22 if (!remainingKeysToPress.length) {
23 if (window.testRunner)
24 testRunner.notifyDone();
27 let nextKey = remainingKeysToPress.shift();
28 UIHelper.typeCharacter(nextKey);
31 function handleKeyDown(event)
36 function handleKeyUp(event)
44 document.getElementById("console").appendChild(document.createTextNode(message + "\n"));
47 function logKeyEvent(event)
50 for (let propertyName of ["type", "key", "code", "keyIdentifier", "keyCode", "charCode", "keyCode", "which"])
51 pieces.push(`${propertyName}: ${event[propertyName]}`);
52 log(pieces.join(", "));
57 if (!window.testRunner)