blob: 7a3acd00d0f1601cb31b98c9b3b228c5cf6f5bf5 [file] [log] [blame]
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN">
<html>
<head>
<script src="../../resources/js-test-pre.js"></script>
</head>
<body>
<p id="description"></p>
<div id="console"></div>
<script>
description('&lt;select&gt; selection test for mouse events and keyevents.');
function mouseDownOnSelect(selId, index, modifier) {
var sl = document.getElementById(selId);
var itemHeight = Math.floor(sl.offsetHeight / sl.size);
var border = 1;
var y = border + index * itemHeight;
sl.focus();
if (window.eventSender) {
eventSender.mouseMoveTo(sl.offsetLeft + border, sl.offsetTop + y - window.pageYOffset);
eventSender.mouseDown(0, [modifier]);
eventSender.mouseUp(0, [modifier]);
}
}
function keyDownOnSelect(selId, identifier, modifier) {
document.getElementById(selId).focus();
if (window.eventSender)
eventSender.keyDown(identifier, [modifier]);
}
function createSelect(idName, sz, mlt, selIndex) {
var sl = document.createElement("select");
var i = 0;
sl.size = sz;
while (i < sz) {
var opt = document.createElement("option");
if (i == selIndex)
opt.selected = true;
opt.textContent = "item " + i;
sl.appendChild(opt);
i++;
}
sl.multiple = mlt;
sl.id = idName;
var parent = document.getElementById("parent");
parent.appendChild(sl);
}
function selectionPattern(selId) {
var sl = document.getElementById(selId);
var result = '';
for (var i = 0; i < sl.options.length; i++)
result += sl.options[i].selected ? '1' : '0';
return result;
}
var parent = document.createElement('div');
parent.id = "parent";
document.body.appendChild(parent);
createSelect("sl1", 5, false, -1);
createSelect("sl2", 5, false, 1);
createSelect("sl3", 5, false, -1);
createSelect("sl4", 5, false, 1);
createSelect("sl5", 5, false, 2);
createSelect("sl6", 5, false, 3);
createSelect("sl7", 5, false, 1);
createSelect("sl8", 5, true, -1);
createSelect("sl9", 5, true, 1);
createSelect("sl10", 5, true, -1);
createSelect("sl11", 5, true, 1);
createSelect("sl12", 5, true, 2);
createSelect("sl13", 5, true, 0);
createSelect("sl14", 5, true, 1);
debug("1) Select one item with mouse (no previous selection)");
mouseDownOnSelect("sl1", 0);
shouldBe('selectionPattern("sl1")', '"10000"');
debug("2) Select one item with mouse (with previous selection)");
mouseDownOnSelect("sl2", 0);
shouldBe('selectionPattern("sl2")', '"10000"');
debug("3) Select one item with the keyboard (no previous selection)");
keyDownOnSelect("sl3", "upArrow");
shouldBe('selectionPattern("sl3")', '"00001"');
debug("4) Select one item with the keyboard (with previous selection)");
keyDownOnSelect("sl4", "downArrow");
shouldBe('selectionPattern("sl4")', '"00100"');
debug("5) Attempt to select an item cmd-clicking");
mouseDownOnSelect("sl5", 1, "addSelectionKey");
shouldBe('selectionPattern("sl5")', '"01000"');
debug("6) Attempt to select a range shift-clicking");
mouseDownOnSelect("sl6", 1, "rangeSelectionKey");
shouldBe('selectionPattern("sl6")', '"01000"');
debug("7) Attempt to select a range with the keyboard");
keyDownOnSelect("sl7", "downArrow", "rangeSelectionKey");
shouldBe('selectionPattern("sl7")', '"00100"');
// Multiple selection tests
debug("8) Select one item with mouse (no previous selection)");
mouseDownOnSelect("sl8", 0);
shouldBe('selectionPattern("sl8")', '"10000"');
debug("9) Select one item with mouse (with previous selection)");
mouseDownOnSelect("sl9", 0);
shouldBe('selectionPattern("sl9")', '"10000"');
debug("10) Select one item with the keyboard (no previous selection)");
keyDownOnSelect("sl10", "upArrow");
shouldBe('selectionPattern("sl10")', '"00001"');
debug("11) Select one item with the keyboard (with previous selection)");
keyDownOnSelect("sl11", "downArrow");
shouldBe('selectionPattern("sl11")', '"00100"');
debug("12) Select an item cmd-clicking");
mouseDownOnSelect("sl12", 1, "addSelectionKey");
shouldBe('selectionPattern("sl12")', '"01100"');
debug("13) Select a range shift-clicking");
mouseDownOnSelect("sl13", 3, "rangeSelectionKey");
shouldBe('selectionPattern("sl13")', '"11110"');
debug("14) Select a range with the keyboard");
keyDownOnSelect("sl14", "downArrow", "rangeSelectionKey");
shouldBe('selectionPattern("sl14")', '"01100"');
</script>
<script src="../../resources/js-test-post.js"></script>
</body>
</html>