зеркало из https://github.com/mozilla/gecko-dev.git
Bug 1385905 - part1: Add automated test to check if editor won't create mozBR element when typing Enter before invisible <br> element r=m_kato
MozReview-Commit-ID: AcHnK2LbTs1 --HG-- extra : rebase_source : a7a5ad16da227db53ab3e7324fa920a6b0276369
This commit is contained in:
Родитель
c80141a452
Коммит
5051f16794
|
@ -247,6 +247,7 @@ skip-if = toolkit == 'android' # bug 1315898
|
|||
[test_bug1358025.html]
|
||||
[test_bug1361008.html]
|
||||
[test_bug1368544.html]
|
||||
[test_bug1385905.html]
|
||||
|
||||
[test_CF_HTML_clipboard.html]
|
||||
subsuite = clipboard
|
||||
|
|
|
@ -0,0 +1,52 @@
|
|||
<!DOCTYPE html>
|
||||
<!--
|
||||
https://bugzilla.mozilla.org/show_bug.cgi=id=1385905
|
||||
-->
|
||||
<html>
|
||||
<head>
|
||||
<script type="application/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
|
||||
<script type="application/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=1385905">Mozilla Bug 1385905</a>
|
||||
<div id="display"></div>
|
||||
<div id="editor" contenteditable style="padding: 5px;"><div>contents</div></div>
|
||||
<pre id="test">
|
||||
</pre>
|
||||
|
||||
<script class="testbody" type="application/javascript">
|
||||
SimpleTest.waitForExplicitFinish();
|
||||
SimpleTest.waitForFocus(() => {
|
||||
SpecialPowers.pushPrefEnv({"set": [["editor.use_div_for_default_newlines", true]]}, () => {
|
||||
function ensureNoMozBR() {
|
||||
for (let br of document.querySelectorAll("#editor > div > br")) {
|
||||
isnot(br.getAttribute("type"), "_moz",
|
||||
"mozBR shouldn't be used with this test");
|
||||
}
|
||||
}
|
||||
var editor = document.getElementById("editor");
|
||||
// Click the left blank area of the first line to set cursor to the start of "contents".
|
||||
synthesizeMouse(editor, 3, 10, {});
|
||||
synthesizeKey("KEY_Enter", { code: "Enter" });
|
||||
is(editor.innerHTML, "<div><br></div><div>contents</div>",
|
||||
"Typing Enter at start of the <div> element should split the <div> element");
|
||||
synthesizeKey("KEY_ArrowUp", { code: "ArrowUp" });
|
||||
synthesizeKey("x", { code: "KeyX" });
|
||||
is(editor.innerHTML, "<div>x<br></div><div>contents</div>",
|
||||
"Typing 'x' at the empty <div> element should just insert 'x' into the <div> element");
|
||||
ensureNoMozBR();
|
||||
synthesizeKey("KEY_Enter", { code: "Enter" });
|
||||
is(editor.innerHTML, "<div>x</div><div><br></div><div>contents</div>",
|
||||
"Typing Enter next to 'x' in the first <div> element should split the <div> element and inserts <br> element to a new <div> element");
|
||||
ensureNoMozBR();
|
||||
synthesizeKey("KEY_Enter", { code: "Enter" });
|
||||
is(editor.innerHTML, "<div>x</div><div><br></div><div><br></div><div>contents</div>",
|
||||
"Typing Enter in the empty <div> should split the <div> element and inserts <br> element to a new <div> element");
|
||||
ensureNoMozBR();
|
||||
SimpleTest.finish();
|
||||
});
|
||||
});
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
Загрузка…
Ссылка в новой задаче