Source code

Revision control

Copy as Markdown

Other Tools

Test Info:

<?xml version="1.0"?>
<?xml-stylesheet href="chrome://global/skin" type="text/css"?>
type="text/css"?>
title="Accessible XUL button hierarchy tests">
<script type="application/javascript"
src="../common.js" />
<script type="application/javascript"
src="../role.js" />
<script type="application/javascript"
src="../events.js" />
<script type="application/javascript">
<![CDATA[
////////////////////////////////////////////////////////////////////////////
// Invokers
function openMenu(aButtonID, aIsTree)
{
var menuItemRole = aIsTree ? ROLE_CHECK_MENU_ITEM : ROLE_MENUITEM;
this.button = getAccessible(aButtonID);
this.menupopup = aIsTree ? this.button.nextSibling : this.button.firstChild;
var checker = new invokerChecker(EVENT_REORDER, this.menupopup);
this.__proto__ = new synthClick(aButtonID, checker);
let testButton = popup => {
var children = [];
if (!aIsTree) {
children.push(popup);
}
var tree = { PUSHBUTTON: children };
testAccessibleTree(this.button, tree);
testAccessibleTree(this.menupop, popup);
}
this.invoke = function openMenu_invoke()
{
testButton({ MENUPOPUP: [ ] });
this.__proto__.invoke();
}
this.finalCheck = function openMenu_finalCheck()
{
testButton({ MENUPOPUP: [
{ role: menuItemRole, children: [ ] },
{ role: menuItemRole, children: [ ] }
] });
synthesizeKey("KEY_Escape");
}
this.getID = function openMenu_getID()
{
return "open menu of the button " + prettyName(aButtonID);
}
}
////////////////////////////////////////////////////////////////////////////
// Do test
gA11yEventDumpToConsole = true; // debug stuff
var gQueue = null;
function doTest()
{
gQueue = new eventQueue();
gQueue.push(new openMenu("button1"));
gQueue.push(new openMenu("button3"));
var columnPickerBtn = getAccessible("tree").firstChild.lastChild.previousSibling;
gQueue.push(new openMenu(columnPickerBtn, true));
gQueue.invoke(); // SimpleTest.finish()
}
SimpleTest.waitForExplicitFinish();
addA11yLoadEvent(doTest);
]]>
</script>
<hbox flex="1" style="overflow: auto;">
<a target="_blank"
title="Ensure accessible children for toolbarbutton types 'menu'">
</a>
<a target="_blank"
title="Don't force accessible creation for popup children">
</a>
<a target="_blank"
title="Column header selection popup no longer exposed to accessibility APIs">
</a>
<br/>
<p id="display"></p>
<div id="content" style="display: none">
</div>
<pre id="test">
</pre>
</body>
<vbox flex="1">
<button id="button1" type="menu" label="button">
<menupopup>
<menuitem label="menuitem"/>
<menuitem label="menuitem"/>
</menupopup>
</button>
<toolbarbutton id="button3" type="menu" label="toolbarbutton">
<menupopup>
<menuitem label="menuitem"/>
<menuitem label="menuitem"/>
</menupopup>
</toolbarbutton>
<tree id="tree" flex="1">
<treecols>
<treecol id="col" flex="1" primary="true" label="column"/>
<treecol id="col2" flex="1" label="another column"/>
</treecols>
<treechildren/>
</tree>
</vbox>
</hbox>
</window>