<!DOCTYPE HTML> <html> <!-- https://bugzilla.mozilla.org/show_bug.cgi?id=864040 --> <head> <meta charset="utf-8"> <title>Test for Bug 864040</title> <script src="/tests/SimpleTest/SimpleTest.js"></script> <script src="/tests/SimpleTest/EventUtils.js"></script> <script src="/tests/SimpleTest/WindowSnapshot.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=864040">Mozilla Bug 864040</a> <div id="display"> <textarea id="ta" rows="5" cols="20" style="-moz-appearance:none"></textarea> <div id="ce" contentEditable="true" style="height: 5em;"></div> </div> <div id="content" style="display: none"> </div> <pre id="test"> <script type="application/javascript"> /** * Test for Bug 864040 * * We use a selection event to set the selection to the end of an editor * containing an ending newline. Then we test to see that the caret is * actually drawn on the newline. */ async function testSelectEndOfText(elem) { var tn = elem.tagName; elem.focus(); // Enter test string into editor var test_string = 'test\n'; sendString(test_string); // Get the caret position after what we entered var result = synthesizeQuerySelectedText(); ok(result, tn + ': failed to query selection (1)'); var refoffset = result.offset; // Take a snapshot of where the caret is (on the new line) referenceSnapshot = await snapshotWindow(window, true /* withCaret */); ok(referenceSnapshot, tn + ': failed to take snapshot (1)'); // Set selection to the same spot through a selection event ok(await synthesizeSelectionSet(refoffset, 0, false), tn + ': failed to set selection'); // Make sure new selection is the same result = synthesizeQuerySelectedText(); ok(result, tn + ': failed to query selection (2)'); is(result.offset, refoffset, tn + ': caret is not at the right position'); // Take a snapshot of where the new caret is (shoud still be on the new line) testSnapshot = await snapshotWindow(window, true /* withCaret */); ok(testSnapshot, tn + ': failed to take snapshot (2)'); // Compare snapshot (should be the same) result = compareSnapshots(referenceSnapshot, testSnapshot, true /* expected */) ok(result, tn + ': failed to compare snapshots'); // result = [correct, s1data, s2data] ok(result[0], tn + ': caret is not on new line'); if (!result[0]) { dump('Ref: ' + result[1] + '\n'); dump('Res: ' + result[2] + '\n'); } } async function runTests() { // we don't test regular <input> because this test is about multiline support // test textarea await testSelectEndOfText(document.getElementById('ta')); // test contentEditable await testSelectEndOfText(document.getElementById('ce')); SimpleTest.finish(); } SimpleTest.waitForExplicitFinish(); SimpleTest.waitForFocus(runTests); </script> </pre> </body> </html>