mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-11-08 20:47:44 +00:00
251 lines
6.7 KiB
HTML
251 lines
6.7 KiB
HTML
|
<!DOCTYPE HTML>
|
||
|
<html class="reftest-wait">
|
||
|
<!--
|
||
|
https://bugzilla.mozilla.org/show_bug.cgi?id=619273
|
||
|
-->
|
||
|
<head>
|
||
|
<title>Test for Bug 619273</title>
|
||
|
<script type="application/javascript;version=1.7">
|
||
|
/** Test DOM mutations inside selection **/
|
||
|
function createDOM(doc) {
|
||
|
let s = doc.createElement('span');
|
||
|
s.appendChild(doc.createTextNode('|'))
|
||
|
let s2 = doc.createElement('span');
|
||
|
s2.appendChild(doc.createTextNode('z'))
|
||
|
s.appendChild(s2)
|
||
|
return s;
|
||
|
}
|
||
|
|
||
|
var tests_done = 0;
|
||
|
var tests = [
|
||
|
function(win,doc,sel) {
|
||
|
doc.body.innerHTML = 'I<br>B<br>C'
|
||
|
let a = doc.body.firstChild;
|
||
|
let r = doc.createRange();
|
||
|
r.setStart(a, 0);
|
||
|
r.setEnd(a, 1);
|
||
|
sel.addRange(r);
|
||
|
doc.body.insertBefore(doc.createTextNode('.'), a);
|
||
|
doc.body.appendChild(createDOM(doc));
|
||
|
},
|
||
|
function(win,doc,sel) {
|
||
|
doc.body.innerHTML = 'I<br>B<br>C'
|
||
|
let a = doc.body.firstChild;
|
||
|
let r = doc.createRange();
|
||
|
r.setStart(doc.firstChild, 0);
|
||
|
r.setEnd(a, 1);
|
||
|
sel.addRange(r);
|
||
|
doc.body.insertBefore(doc.createTextNode('.'), a);
|
||
|
doc.body.appendChild(createDOM(doc));
|
||
|
},
|
||
|
function(win,doc,sel) {
|
||
|
doc.body.innerHTML = 'I<br>B<br>C'
|
||
|
let a = doc.body.firstChild;
|
||
|
let b = doc.body.childNodes[2];
|
||
|
let c = doc.body.childNodes[4];
|
||
|
let r = doc.createRange();
|
||
|
r.setStart(a, 0);
|
||
|
r.setEnd(c, 1);
|
||
|
sel.addRange(r);
|
||
|
doc.body.insertBefore(doc.createTextNode('.'), b);
|
||
|
doc.body.appendChild(createDOM(doc));
|
||
|
},
|
||
|
function(win,doc,sel) {
|
||
|
doc.body.innerHTML = 'I<br>B<br>C'
|
||
|
let b = doc.body.childNodes[2];
|
||
|
let c = doc.body.childNodes[4];
|
||
|
let r = doc.createRange();
|
||
|
r.setStart(doc.body, 0);
|
||
|
r.setEnd(c, 1);
|
||
|
sel.addRange(r);
|
||
|
doc.body.insertBefore(doc.createTextNode('.'), b);
|
||
|
doc.body.appendChild(createDOM(doc));
|
||
|
},
|
||
|
function(win,doc,sel) {
|
||
|
doc.body.innerHTML = 'I<br>B<br>C'
|
||
|
let b = doc.body.childNodes[2];
|
||
|
let c = doc.body.childNodes[4];
|
||
|
let r = doc.createRange();
|
||
|
r.setStart(doc, 0);
|
||
|
r.setEnd(c, 1);
|
||
|
sel.addRange(r);
|
||
|
doc.body.insertBefore(doc.createTextNode('.'), b);
|
||
|
doc.body.appendChild(createDOM(doc));
|
||
|
},
|
||
|
function(win,doc,sel) {
|
||
|
doc.body.innerHTML = 'I<br>B<br>C'
|
||
|
let a = doc.body.firstChild;
|
||
|
let c = doc.body.childNodes[4];
|
||
|
let r = doc.createRange();
|
||
|
r.setStart(a, 0);
|
||
|
r.setEnd(c, 1);
|
||
|
sel.addRange(r);
|
||
|
doc.body.insertBefore(doc.createTextNode('.'), c);
|
||
|
doc.body.appendChild(createDOM(doc));
|
||
|
},
|
||
|
|
||
|
function(win,doc,sel) {
|
||
|
doc.body.innerHTML = 'I<br>B<br>C'
|
||
|
let a = doc.body.firstChild;
|
||
|
let r = doc.createRange();
|
||
|
r.setStart(a, 0);
|
||
|
r.setEnd(a, 1);
|
||
|
sel.addRange(r);
|
||
|
let span = createDOM(doc);
|
||
|
doc.body.insertBefore(span, a);
|
||
|
span.appendChild(createDOM(doc));
|
||
|
},
|
||
|
function(win,doc,sel) {
|
||
|
doc.body.innerHTML = 'I<br>B<br>C'
|
||
|
let a = doc.body.firstChild;
|
||
|
let r = doc.createRange();
|
||
|
r.setStart(doc.firstChild, 0);
|
||
|
r.setEnd(a, 1);
|
||
|
sel.addRange(r);
|
||
|
let span = createDOM(doc);
|
||
|
doc.body.insertBefore(span, a);
|
||
|
span.appendChild(createDOM(doc));
|
||
|
},
|
||
|
function(win,doc,sel) {
|
||
|
doc.body.innerHTML = 'I<br>B<br>C'
|
||
|
let a = doc.body.firstChild;
|
||
|
let b = doc.body.childNodes[2];
|
||
|
let c = doc.body.childNodes[4];
|
||
|
let r = doc.createRange();
|
||
|
r.setStart(a, 0);
|
||
|
r.setEnd(c, 1);
|
||
|
sel.addRange(r);
|
||
|
let span = createDOM(doc);
|
||
|
doc.body.insertBefore(span, b);
|
||
|
span.appendChild(createDOM(doc));
|
||
|
},
|
||
|
function(win,doc,sel) {
|
||
|
doc.body.innerHTML = 'I<br>B<br>C'
|
||
|
let b = doc.body.childNodes[2];
|
||
|
let c = doc.body.childNodes[4];
|
||
|
let r = doc.createRange();
|
||
|
r.setStart(doc.body, 0);
|
||
|
r.setEnd(c, 1);
|
||
|
sel.addRange(r);
|
||
|
let span = createDOM(doc);
|
||
|
doc.body.insertBefore(span, b);
|
||
|
span.appendChild(createDOM(doc));
|
||
|
},
|
||
|
function(win,doc,sel) {
|
||
|
doc.body.innerHTML = 'I<br>B<br>C'
|
||
|
let b = doc.body.childNodes[2];
|
||
|
let c = doc.body.childNodes[4];
|
||
|
let r = doc.createRange();
|
||
|
r.setStart(doc, 0);
|
||
|
r.setEnd(c, 1);
|
||
|
sel.addRange(r);
|
||
|
let span = createDOM(doc);
|
||
|
doc.body.insertBefore(span, b);
|
||
|
span.appendChild(createDOM(doc));
|
||
|
},
|
||
|
function(win,doc,sel) {
|
||
|
doc.body.innerHTML = 'I<br>B<br>C'
|
||
|
let a = doc.body.firstChild;
|
||
|
let c = doc.body.childNodes[4];
|
||
|
let r = doc.createRange();
|
||
|
r.setStart(a, 0);
|
||
|
r.setEnd(c, 1);
|
||
|
sel.addRange(r);
|
||
|
let span = createDOM(doc);
|
||
|
doc.body.insertBefore(span, c);
|
||
|
span.appendChild(createDOM(doc));
|
||
|
},
|
||
|
|
||
|
function(win,doc,sel) {
|
||
|
doc.body.innerHTML = 'I<br>B<br>C'
|
||
|
let a = doc.body.firstChild;
|
||
|
let r = doc.createRange();
|
||
|
r.setStart(a, 0);
|
||
|
r.setEnd(a, 1);
|
||
|
sel.addRange(r);
|
||
|
doc.body.appendChild(a);
|
||
|
},
|
||
|
function(win,doc,sel) {
|
||
|
doc.body.innerHTML = 'I<br>B<br>C'
|
||
|
let a = doc.body.firstChild;
|
||
|
let r = doc.createRange();
|
||
|
r.setStart(a, 0);
|
||
|
r.setEnd(a, 1);
|
||
|
sel.addRange(r);
|
||
|
document.adoptNode(a);
|
||
|
document.body.appendChild(a);
|
||
|
document.body.appendChild(document.createTextNode(' '));
|
||
|
},
|
||
|
function(win,doc,sel) {
|
||
|
doc.body.innerHTML = 'I<br>B<br>C'
|
||
|
let a = doc.body.firstChild;
|
||
|
let c = doc.body.childNodes[4];
|
||
|
let r = doc.createRange();
|
||
|
r.setStart(a, 0);
|
||
|
r.setEnd(c, 1);
|
||
|
sel.addRange(r);
|
||
|
let span = createDOM(doc);
|
||
|
doc.body.insertBefore(span, c);
|
||
|
document.adoptNode(span);
|
||
|
document.body.appendChild(span);
|
||
|
},
|
||
|
|
||
|
function(win,doc,sel) {
|
||
|
doc.body.innerHTML = 'I'
|
||
|
let a = doc.body.firstChild;
|
||
|
let span = createDOM(doc);
|
||
|
let r = doc.createRange();
|
||
|
r.setStart(span, 0);
|
||
|
r.setEnd(span, 1);
|
||
|
sel.addRange(r);
|
||
|
doc.body.appendChild(span);
|
||
|
},
|
||
|
|
||
|
function(win,doc,sel) {
|
||
|
doc.body.innerHTML = 'I'
|
||
|
let a = doc.body.firstChild;
|
||
|
let span = createDOM(doc);
|
||
|
let r = doc.createRange();
|
||
|
r.setStart(span.firstChild, 0);
|
||
|
r.setEnd(span.firstChild, 1);
|
||
|
sel.addRange(r);
|
||
|
doc.body.appendChild(span);
|
||
|
doc.body.appendChild(span.firstChild);
|
||
|
r.setEnd(span.firstChild, 1);
|
||
|
},
|
||
|
]
|
||
|
|
||
|
function runTestInIframe(run,t) {
|
||
|
let f = document.createElement('iframe');
|
||
|
f.setAttribute('frameborder','0');
|
||
|
f.setAttribute('height','100');
|
||
|
f.setAttribute('width','200');
|
||
|
f.src = 'data:text/html,<body style="margin:0;padding:0;font-family:monospace">';
|
||
|
f.onload = function () {
|
||
|
try {
|
||
|
run(f.contentWindow, f.contentDocument, f.contentWindow.getSelection());
|
||
|
} finally { ++tests_done; }
|
||
|
}
|
||
|
return f;
|
||
|
}
|
||
|
|
||
|
var id;
|
||
|
function checkFinished() {
|
||
|
if (window.frames.length == tests_done) {
|
||
|
clearInterval(id);
|
||
|
document.documentElement.className = "";
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function runTest() {
|
||
|
for (let i=0; i < tests.length; ++i) {
|
||
|
let t = tests[i];
|
||
|
document.body.appendChild(runTestInIframe(t));
|
||
|
}
|
||
|
id = setInterval(checkFinished,500);
|
||
|
}
|
||
|
</script>
|
||
|
</head>
|
||
|
<body onload="runTest()"></body>
|
||
|
</html>
|