1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119
|
<!DOCTYPE html>
<html lang="en">
<title>HTMLSelectMenuElement Test: ask-for-reset</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<form name="fm1" id="form1">
<selectmenu id="selectmenu1">
<option>one</option>
<option>two</option>
</selectmenu>
<selectmenu id="selectmenu2">
<option>one</option>
<option selected>two</option>
</selectmenu>
<selectmenu id="selectmenu3">
<option>one</option>
<option selected>two</option>
<option selected>three</option>
</selectmenu>
</form>
<script>
function createSelectMenu(numberOfOptions) {
let selectMenu = document.createElement("selectmenu");
for (let i = 0; i < numberOfOptions; i++) {
let option = document.createElement("option");
option.value = i;
selectMenu.appendChild(option);
}
return selectMenu;
}
function checkSelection(selectMenu, selectedOptionIndex, msg) {
for (let i = 0; i < selectMenu.children.length; i++) {
if (i != selectedOptionIndex) {
assert_false(selectMenu.children[i].selected);
}
}
assert_true(selectMenu.children[selectedOptionIndex].selected, msg);
assert_equals(selectMenu.value, selectMenu.children[selectedOptionIndex].value);
}
test(() => {
let selectMenu = createSelectMenu(5);
selectMenu.children[4].selected = true;
checkSelection(selectMenu, 4);
selectMenu.children[4].remove();
checkSelection(selectMenu, 0, "After removing the selected option, selection should default to first option.");
selectMenu.children[3].selected = true;
checkSelection(selectMenu, 3);
selectMenu.children[0].remove();
checkSelection(selectMenu, 2, "Removing non-selected option should have no effect.");
}, "ask-for-reset when removing option");
test(() => {
let selectMenu = createSelectMenu(3);
selectMenu.children[1].selected = true;
let newOption = document.createElement("option");
newOption.selected = true;
selectMenu.appendChild(newOption);
checkSelection(selectMenu, 3, "Inserting a selected option should update selection.");
let newOption2 = document.createElement("option");
newOption2.selected = true;
selectMenu.prepend(newOption2);
checkSelection(selectMenu, 0, "Inserting a selected option should update selection, even though it's not last in tree order.");
let newOption3 = document.createElement("option");
selectMenu.appendChild(newOption3);
checkSelection(selectMenu, 0, "Inserting a non-selected option should have no effect.");
}, "ask-for-reset when inserting option");
test(() => {
let selectMenu = createSelectMenu(3);
let options = selectMenu.children;
// select options from first to last
for (let i = 0; i < options.length; i++) {
options[i].selected = true;
checkSelection(selectMenu, i);
}
// select options from last to first
for (let i = options.length - 1; i >= 0; i--) {
options[i].selected = true;
checkSelection(selectMenu, i);
}
options[2].selected = true;
checkSelection(selectMenu, 2);
options[2].selected = false;
checkSelection(selectMenu, 0, "First non-disabled option should be selected.");
options[0].disabled = true;
options[2].selected = true;
checkSelection(selectMenu, 2);
options[2].selected = false;
checkSelection(selectMenu, 1, "First non-disabled option should be selected.");
}, "ask-for-reset when changing selectedness of option");
test(() => {
let selectMenu1 = document.getElementById("selectmenu1");
let selectMenu2 = document.getElementById("selectmenu2");
let selectMenu3 = document.getElementById("selectmenu3");
document.getElementById("form1").reset();
assert_equals(selectMenu1.value, "one", "First non-disabled option should be selected.");
assert_equals(selectMenu2.value, "two", "The selected option should be selected.");
assert_equals(selectMenu3.value, "three", "Last selected option should be selected.")
}, "ask-for-reset for form");
</script>
|