<!DOCTYPE HTML> <html> <!-- https://bugzilla.mozilla.org/show_bug.cgi?id=617528 --> <head> <title>Test for Bug 617528</title> <script type="application/javascript" src="/tests/SimpleTest/SimpleTest.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=617528">Mozilla Bug 617528</a> <p id="display"></p> <div id="content"> <menu> <menuitem id="checkbox" type="checkbox" label="Checkbox" checked></menuitem> <menuitem id="radio1" type="radio" label="Radio1" checked></menuitem> <menuitem id="radio2" type="radio" label="Radio2"></menuitem> </menu> </div> <pre id="test"> <script type="application/javascript"> /** Test for Bug 617528 **/ SimpleTest.waitForExplicitFinish(); addLoadEvent(function() { function click(element, preventDefault, checked) { function handleClick(event) { is(this.checked, checked, "checking .checked (" + this.id + ")"); if (preventDefault) event.preventDefault(); } element.addEventListener("click", handleClick); element.click(); element.removeEventListener("click", handleClick); } function verify(elements, data) { for (var i = 0; i < elements.length; i++) { var element = elements[i]; is(element.checked, data[i*2], "checking .checked (" + element.id + ")"); is(element.defaultChecked, data[i*2+1], 'checking .defaultChecked (' + element.id + ")"); } } var checkbox = document.getElementById("checkbox"); click(checkbox, false, false); verify([checkbox], [false, true]); click(checkbox, true, true); verify([checkbox], [false, true]); var radio1 = document.getElementById("radio1"); var radio2 = document.getElementById("radio2"); click(radio2, false, true); verify([radio1, radio2], [false, true, true, false]); click(radio1, true, true); verify([radio1, radio2], [false, true, true, false]); SimpleTest.finish(); }); </script> </pre> </body> </html>