зеркало из https://github.com/mozilla/gecko-dev.git
224 строки
7.6 KiB
HTML
224 строки
7.6 KiB
HTML
<!DOCTYPE HTML>
|
|
<html class="reftest-wait"><head>
|
|
<meta charset="utf-8">
|
|
<title>Testcase #1 for bug 1129078</title>
|
|
<script src="/tests/SimpleTest/SimpleTest.js"></script>
|
|
<script src="/tests/SimpleTest/EventUtils.js"></script>
|
|
<script src="selection-utils.js"></script>
|
|
|
|
<style type="text/css">
|
|
@font-face {
|
|
font-family: Ahem;
|
|
src: url("Ahem.ttf");
|
|
}
|
|
html,body { margin:0; padding: 0; }
|
|
body,pre { font-family: Ahem; font-size: 20px; }
|
|
span { -moz-user-select:none; }
|
|
x { -moz-user-select:text; }
|
|
</style>
|
|
</head>
|
|
<body>
|
|
|
|
<pre id="select">
|
|
2af45494-a<x>k7e-1</x><span id="span2">1e4-a0c6-a7e7
|
|
38222880-bj6d-11e4-8064-fb7b
|
|
3d649ae</span><x>4-ci5</x><span id="span3">c-11e4-995d-17b2
|
|
434351bc-dh4b-11e4-9971-4fc8
|
|
4dc0e0b4-eg4a-11e4-8c28-5319
|
|
a9631</span><x>9c8-ad7d-1</x>1e4-b312-039c
|
|
</pre>
|
|
|
|
<pre id="log" style="border:1px solid green"></pre>
|
|
|
|
<script>
|
|
window.info = parent.info;
|
|
window.is = parent.is;
|
|
window.isnot = parent.isnot;
|
|
window.ok = parent.ok;
|
|
|
|
var sel = window.getSelection();
|
|
|
|
function enableSelection(id) {
|
|
var span = document.getElementById(id);
|
|
span.style.MozUserSelect = 'text';
|
|
}
|
|
|
|
function setupPrevSelection() {
|
|
var e = document.querySelector('#select');
|
|
dragSelectPoints(e, 300, 125, 200, 5);
|
|
}
|
|
|
|
function setupNextSelection() {
|
|
var e = document.querySelector('#select');
|
|
dragSelectPoints(e, 199, 5, 300, 125);
|
|
}
|
|
|
|
var ops = {
|
|
S_ : shiftClick,
|
|
SA : shiftAccelClick,
|
|
AD : accelDragSelect,
|
|
SL : keyLeft,
|
|
SR : keyRight
|
|
}
|
|
|
|
function runTest() {
|
|
sel = window.getSelection();
|
|
sel.removeAllRanges();
|
|
document.body.offsetHeight;
|
|
var e = document.querySelector('#select');
|
|
var hash = window.location.hash
|
|
if (hash.substring(0,5)=="#prev")
|
|
setupPrevSelection();
|
|
else
|
|
setupNextSelection();
|
|
var op = hash.substring(6,8);
|
|
var action = ops[op];
|
|
var test = hash.substring(0,6);
|
|
if (hash.substring(0,5) == "#prev") {
|
|
if (test == "#prev1") {
|
|
if (action == keyLeft) {
|
|
keyLeft({shiftKey:true}, 2)
|
|
checkRanges([[0,8,-1,2], [3,0,-1,4], [5,0,6,0]], e);
|
|
} else if (action == keyRight) {
|
|
keyRight({shiftKey:true}, 2)
|
|
checkRanges([[e.childNodes[1].firstChild,2,-1,2], [3,0,-1,4], [5,0,6,0]], e);
|
|
} else if (action == accelDragSelect) {
|
|
accelDragSelect(e, 30, 50);
|
|
checkRanges([[0,1,0,2], [e.childNodes[1].firstChild,0,-1,2], [3,0,-1,4], [5,0,6,0]], e);
|
|
} else {
|
|
action(e, 30);
|
|
checkRanges([[0,1,-1,2], [3,0,-1,4], [5,0,6,0]], e);
|
|
}
|
|
} else if (test == "#prev2") {
|
|
action(e, 260);
|
|
checkRangeCount(3, e);
|
|
checkRange(0, [0,3,-2,2], e.childNodes[1]);
|
|
checkRange(1, [3,0,-1,4], e);
|
|
checkRange(2, [5,0,6,0], e);
|
|
} else if (test == "#prev3") {
|
|
enableSelection('span2');
|
|
action(e, 400);
|
|
checkRangeCount(2, e);
|
|
checkRange(0, [0,5,-2,4], e.childNodes[2]);
|
|
checkRange(1, [5,0,6,0], e);
|
|
} else if (test == "#prev4") {
|
|
action(e, 180, 65);
|
|
checkRangeCount(2, e);
|
|
checkRange(0, [0,2,-2,4], e.childNodes[3]);
|
|
checkRange(1, [5,0,6,0], e);
|
|
} else if (test == "#prev5") {
|
|
enableSelection('span3');
|
|
action(e, 440, 65);
|
|
checkRangeCount(1, e);
|
|
checkRangePoints(0, [e.childNodes[4].firstChild,10,e.childNodes[6],0], e);
|
|
} else if (test == "#prev6") {
|
|
action(e, 140, 125);
|
|
checkRangeCount(1, e);
|
|
checkRangePoints(0, [e.childNodes[5].firstChild,2,e.childNodes[6],0], e);
|
|
} else if (test == "#prev7") {
|
|
if (action == accelDragSelect) {
|
|
accelDragSelect(e, 460, 500, 125);
|
|
checkRanges([[e.childNodes[1].firstChild,0,-1,2], [3,0,-1,4], [5,0,6,0], [6,8,6,10]], e);
|
|
} else {
|
|
action(e, 500, 125);
|
|
checkRanges([[6,0,6,10]], e);
|
|
}
|
|
} else if (test == "#prev8") {
|
|
if (action == accelDragSelect) {
|
|
sel.removeAllRanges();
|
|
var e = document.querySelector('#select');
|
|
synthesizeMouse(e, 200, 125, {type: "mousedown", accelKey: true});
|
|
synthesizeMouse(e, 200, 120, {type: "mousemove", accelKey: true});
|
|
synthesizeMouse(e, 200, 100, {type: "mousemove", accelKey: true});
|
|
synthesizeMouse(e, 200, 80, {type: "mousemove", accelKey: true});
|
|
synthesizeMouse(e, 210, 60, {type: "mousemove", accelKey: true});
|
|
synthesizeMouse(e, 200, 60, {type: "mousemove", accelKey: true});
|
|
synthesizeMouse(e, 200, 60, {type: "mouseup", accelKey: true});
|
|
var x3t = e.childNodes[3].firstChild;
|
|
var x5 = e.childNodes[5];
|
|
checkRanges([[x3t,3,-1,4], [x5,0,x5.firstChild,5]], e);
|
|
}
|
|
}
|
|
} else {
|
|
if (test == "#next1") {
|
|
if (action == keyLeft) {
|
|
keyLeft({shiftKey:true}, 2)
|
|
checkRanges([[0,10,-1,2], [3,0,-1,4], [5,0,e.childNodes[5].firstChild,8]], e);
|
|
} else if (action == keyRight) {
|
|
keyRight({shiftKey:true}, 2)
|
|
checkRanges([[0,10,-1,2], [3,0,-1,4], [5,0,6,2]], e);
|
|
} else if (action == accelDragSelect) {
|
|
accelDragSelect(e, 30, 50);
|
|
checkRanges([[0,1,0,2], [0,10,-1,2], [3,0,-1,4], [5,0,e.childNodes[5].firstChild,10]], e);
|
|
} else {
|
|
action(e, 30);
|
|
checkRanges([[0,1,0,10]], e);
|
|
}
|
|
} else if (test == "#next2") {
|
|
action(e, 260);
|
|
checkRangeCount(1, e);
|
|
checkRangePoints(0, [e.childNodes[0],10,e.childNodes[1].firstChild,3], e);
|
|
} else if (test == "#next3") {
|
|
enableSelection('span2');
|
|
action(e, 400);
|
|
checkRangeCount(1, e);
|
|
checkRangePoints(0, [e.childNodes[0],10,e.childNodes[2].firstChild,5], e);
|
|
} else if (test == "#next4") {
|
|
action(e, 180, 65);
|
|
checkRangeCount(2, e);
|
|
checkRange(0, [0,10,-1,2], e);
|
|
checkRange(1, [-1,0,0,2], e.childNodes[3]);
|
|
} else if (test == "#next5") {
|
|
enableSelection('span3');
|
|
action(e, 440, 65);
|
|
checkRangeCount(2, e);
|
|
checkRange(0, [0,10,-1,2], e);
|
|
checkRangePoints(1, [e.childNodes[3],0,e.childNodes[4].firstChild,10], e);
|
|
} else if (test == "#next6") {
|
|
action(e, 140, 125);
|
|
checkRangeCount(3, e);
|
|
checkRange(0, [0,10,-1,2], e);
|
|
checkRange(1, [3,0,-1,4], e);
|
|
checkRange(2, [-1,0,0,2], e.childNodes[5]);
|
|
} else if (test == "#next7") {
|
|
if (action == keyRight) {
|
|
keyRight({shiftKey:true}, 2)
|
|
checkRanges([[0,10,-1,2], [3,0,-1,4], [5,0,6,2]], e);
|
|
} else if (action == accelDragSelect) {
|
|
accelDragSelect(e, 460, 500, 125);
|
|
checkRanges([[0,10,-1,2], [3,0,-1,4], [5,0,e.childNodes[5].firstChild,10], [6,8,6,10]], e);
|
|
} else {
|
|
action(e, 500, 125);
|
|
checkRangeCount(3, e);
|
|
checkRange(0, [0,10,-1,2], e);
|
|
checkRange(1, [3,0,-1,4], e);
|
|
checkRangePoints(2, [e.childNodes[5],0,e.childNodes[6],10], e);
|
|
}
|
|
} else if (test == "#next8") {
|
|
if (action == accelDragSelect) {
|
|
sel.removeAllRanges();
|
|
var e = document.querySelector('#select');
|
|
synthesizeMouse(e, 200, 60, {type: "mousedown", accelKey: true});
|
|
synthesizeMouse(e, 180, 60, {type: "mousemove", accelKey: true});
|
|
synthesizeMouse(e, 200, 80, {type: "mousemove", accelKey: true});
|
|
synthesizeMouse(e, 200, 100, {type: "mousemove", accelKey: true});
|
|
synthesizeMouse(e, 200, 120, {type: "mousemove", accelKey: true});
|
|
synthesizeMouse(e, 190, 125, {type: "mousemove", accelKey: true});
|
|
synthesizeMouse(e, 200, 125, {type: "mousemove", accelKey: true});
|
|
synthesizeMouse(e, 200, 125, {type: "mouseup", accelKey: true});
|
|
var x3t = e.childNodes[3].firstChild;
|
|
var x5 = e.childNodes[5];
|
|
checkRanges([[x3t,3,-1,4], [x5,0,x5.firstChild,5]], e);
|
|
}
|
|
}
|
|
}
|
|
document.documentElement.removeAttribute("class");
|
|
}
|
|
|
|
SimpleTest.waitForFocus(function(){setTimeout(runTest,0)});
|
|
|
|
</script>
|
|
|
|
</body>
|
|
</html>
|