mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-10-15 22:35:43 +00:00
Bug 630486 - ASSERTION 'Want to fire mutation events, but it's not safe' in nsContentUtils::HasMutationListeners triggered by a11y, r=marcoz, gavin, bz, f=davidb
--HG-- rename : accessible/tests/mochitest/tree/test_colorpicker.xul => accessible/tests/mochitest/treeupdate/test_colorpicker.xul rename : accessible/tests/mochitest/tree/test_button.xul => accessible/tests/mochitest/treeupdate/test_menubutton.xul
This commit is contained in:
parent
5d950fcb8f
commit
12f39cb5d2
@ -64,7 +64,6 @@ ACCESSIBILITY_ATOM(_false, "false")
|
|||||||
ACCESSIBILITY_ATOM(image, "image")
|
ACCESSIBILITY_ATOM(image, "image")
|
||||||
ACCESSIBILITY_ATOM(menu, "menu")
|
ACCESSIBILITY_ATOM(menu, "menu")
|
||||||
ACCESSIBILITY_ATOM(menuButton, "menu-button")
|
ACCESSIBILITY_ATOM(menuButton, "menu-button")
|
||||||
ACCESSIBILITY_ATOM(menugenerated, "menugenerated")
|
|
||||||
ACCESSIBILITY_ATOM(multiple, "multiple")
|
ACCESSIBILITY_ATOM(multiple, "multiple")
|
||||||
ACCESSIBILITY_ATOM(open, "open")
|
ACCESSIBILITY_ATOM(open, "open")
|
||||||
ACCESSIBILITY_ATOM(password, "password")
|
ACCESSIBILITY_ATOM(password, "password")
|
||||||
|
@ -761,47 +761,6 @@ nsCoreUtils::IsColumnHidden(nsITreeColumn *aColumn)
|
|||||||
nsAccessibilityAtoms::_true, eCaseMatters);
|
nsAccessibilityAtoms::_true, eCaseMatters);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
|
||||||
nsCoreUtils::GeneratePopupTree(nsIContent *aContent, PRBool aIsAnon)
|
|
||||||
{
|
|
||||||
// Set menugenerated="true" on the menupopup node to generate the sub-menu
|
|
||||||
// items if they have not been generated.
|
|
||||||
|
|
||||||
nsCOMPtr<nsIDOMNodeList> list;
|
|
||||||
if (aIsAnon) {
|
|
||||||
nsIDocument* document = aContent->GetCurrentDoc();
|
|
||||||
if (document)
|
|
||||||
document->GetXBLChildNodesFor(aContent, getter_AddRefs(list));
|
|
||||||
|
|
||||||
} else {
|
|
||||||
list = aContent->GetChildNodesList();
|
|
||||||
}
|
|
||||||
|
|
||||||
PRUint32 length = 0;
|
|
||||||
if (!list || NS_FAILED(list->GetLength(&length)))
|
|
||||||
return;
|
|
||||||
|
|
||||||
for (PRUint32 idx = 0; idx < length; idx++) {
|
|
||||||
nsCOMPtr<nsIDOMNode> childNode;
|
|
||||||
list->Item(idx, getter_AddRefs(childNode));
|
|
||||||
nsCOMPtr<nsIContent> child(do_QueryInterface(childNode));
|
|
||||||
|
|
||||||
PRBool isPopup = child->NodeInfo()->Equals(nsAccessibilityAtoms::menupopup,
|
|
||||||
kNameSpaceID_XUL) ||
|
|
||||||
child->NodeInfo()->Equals(nsAccessibilityAtoms::panel,
|
|
||||||
kNameSpaceID_XUL);
|
|
||||||
if (isPopup && !child->AttrValueIs(kNameSpaceID_None,
|
|
||||||
nsAccessibilityAtoms::menugenerated,
|
|
||||||
nsAccessibilityAtoms::_true,
|
|
||||||
eCaseMatters)) {
|
|
||||||
|
|
||||||
child->SetAttr(kNameSpaceID_None, nsAccessibilityAtoms::menugenerated,
|
|
||||||
NS_LITERAL_STRING("true"), PR_TRUE);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
// nsAccessibleDOMStringList
|
// nsAccessibleDOMStringList
|
||||||
|
@ -367,16 +367,6 @@ public:
|
|||||||
return aContent->NodeInfo()->Equals(nsAccessibilityAtoms::th) ||
|
return aContent->NodeInfo()->Equals(nsAccessibilityAtoms::th) ||
|
||||||
aContent->HasAttr(kNameSpaceID_None, nsAccessibilityAtoms::scope);
|
aContent->HasAttr(kNameSpaceID_None, nsAccessibilityAtoms::scope);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Generates frames for popup subtree.
|
|
||||||
*
|
|
||||||
* @param aContent [in] DOM node containing the menupopup element as a child
|
|
||||||
* @param aIsAnon [in] specifies whether popup should be searched inside of
|
|
||||||
* anonymous or explicit content
|
|
||||||
*/
|
|
||||||
static void GeneratePopupTree(nsIContent *aContent,
|
|
||||||
PRBool aIsAnon = PR_FALSE);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -116,19 +116,6 @@ nsXULColorPickerAccessible::
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// nsXULColorPickerAccessible: nsAccessNode
|
|
||||||
|
|
||||||
PRBool
|
|
||||||
nsXULColorPickerAccessible::Init()
|
|
||||||
{
|
|
||||||
if (!nsXULColorPickerTileAccessible::Init())
|
|
||||||
return PR_FALSE;
|
|
||||||
|
|
||||||
nsCoreUtils::GeneratePopupTree(mContent, PR_TRUE);
|
|
||||||
return PR_TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
// nsXULColorPickerAccessible: nsAccessible
|
// nsXULColorPickerAccessible: nsAccessible
|
||||||
|
|
||||||
|
@ -68,9 +68,6 @@ class nsXULColorPickerAccessible : public nsXULColorPickerTileAccessible
|
|||||||
public:
|
public:
|
||||||
nsXULColorPickerAccessible(nsIContent *aContent, nsIWeakReference *aShell);
|
nsXULColorPickerAccessible(nsIContent *aContent, nsIWeakReference *aShell);
|
||||||
|
|
||||||
// nsAccessNode
|
|
||||||
virtual PRBool Init();
|
|
||||||
|
|
||||||
// nsAccessible
|
// nsAccessible
|
||||||
virtual PRUint32 NativeRole();
|
virtual PRUint32 NativeRole();
|
||||||
virtual PRUint64 NativeState();
|
virtual PRUint64 NativeState();
|
||||||
|
@ -57,16 +57,6 @@ nsXULComboboxAccessible::
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
PRBool
|
|
||||||
nsXULComboboxAccessible::Init()
|
|
||||||
{
|
|
||||||
if (!nsAccessibleWrap::Init())
|
|
||||||
return PR_FALSE;
|
|
||||||
|
|
||||||
nsCoreUtils::GeneratePopupTree(mContent);
|
|
||||||
return PR_TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
PRUint32
|
PRUint32
|
||||||
nsXULComboboxAccessible::NativeRole()
|
nsXULComboboxAccessible::NativeRole()
|
||||||
{
|
{
|
||||||
|
@ -60,9 +60,6 @@ public:
|
|||||||
NS_IMETHOD GetNumActions(PRUint8 *aNumActions);
|
NS_IMETHOD GetNumActions(PRUint8 *aNumActions);
|
||||||
NS_IMETHOD GetActionName(PRUint8 aIndex, nsAString& aName);
|
NS_IMETHOD GetActionName(PRUint8 aIndex, nsAString& aName);
|
||||||
|
|
||||||
// nsAccessNode
|
|
||||||
virtual PRBool Init();
|
|
||||||
|
|
||||||
// nsAccessible
|
// nsAccessible
|
||||||
virtual PRUint32 NativeRole();
|
virtual PRUint32 NativeRole();
|
||||||
virtual PRUint64 NativeState();
|
virtual PRUint64 NativeState();
|
||||||
|
@ -109,21 +109,6 @@ nsXULButtonAccessible::DoAction(PRUint8 aIndex)
|
|||||||
return NS_OK;
|
return NS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// nsXULButtonAccessible: nsAccessNode
|
|
||||||
|
|
||||||
PRBool
|
|
||||||
nsXULButtonAccessible::Init()
|
|
||||||
{
|
|
||||||
if (!nsAccessibleWrap::Init())
|
|
||||||
return PR_FALSE;
|
|
||||||
|
|
||||||
if (ContainsMenu())
|
|
||||||
nsCoreUtils::GeneratePopupTree(mContent);
|
|
||||||
|
|
||||||
return PR_TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
// nsXULButtonAccessible: nsAccessible
|
// nsXULButtonAccessible: nsAccessible
|
||||||
|
|
||||||
|
@ -66,9 +66,6 @@ public:
|
|||||||
NS_IMETHOD GetActionName(PRUint8 aIndex, nsAString& aName);
|
NS_IMETHOD GetActionName(PRUint8 aIndex, nsAString& aName);
|
||||||
NS_IMETHOD DoAction(PRUint8 index);
|
NS_IMETHOD DoAction(PRUint8 index);
|
||||||
|
|
||||||
// nsAccessNode
|
|
||||||
virtual PRBool Init();
|
|
||||||
|
|
||||||
// nsAccessible
|
// nsAccessible
|
||||||
virtual PRUint32 NativeRole();
|
virtual PRUint32 NativeRole();
|
||||||
virtual PRUint64 NativeState();
|
virtual PRUint64 NativeState();
|
||||||
|
@ -280,16 +280,6 @@ nsXULMenuitemAccessible::
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
PRBool
|
|
||||||
nsXULMenuitemAccessible::Init()
|
|
||||||
{
|
|
||||||
if (!nsAccessibleWrap::Init())
|
|
||||||
return PR_FALSE;
|
|
||||||
|
|
||||||
nsCoreUtils::GeneratePopupTree(mContent);
|
|
||||||
return PR_TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
PRUint64
|
PRUint64
|
||||||
nsXULMenuitemAccessible::NativeState()
|
nsXULMenuitemAccessible::NativeState()
|
||||||
{
|
{
|
||||||
|
@ -89,9 +89,6 @@ public:
|
|||||||
NS_IMETHOD GetActionName(PRUint8 aIndex, nsAString& aName);
|
NS_IMETHOD GetActionName(PRUint8 aIndex, nsAString& aName);
|
||||||
NS_IMETHOD GetNumActions(PRUint8 *_retval);
|
NS_IMETHOD GetNumActions(PRUint8 *_retval);
|
||||||
|
|
||||||
// nsAccessNode
|
|
||||||
virtual PRBool Init();
|
|
||||||
|
|
||||||
// nsAccessible
|
// nsAccessible
|
||||||
virtual nsresult GetNameInternal(nsAString& aName);
|
virtual nsresult GetNameInternal(nsAString& aName);
|
||||||
virtual PRUint32 NativeRole();
|
virtual PRUint32 NativeRole();
|
||||||
|
@ -29,7 +29,12 @@
|
|||||||
{
|
{
|
||||||
ID: "menu",
|
ID: "menu",
|
||||||
actionName: "click",
|
actionName: "click",
|
||||||
events: CLICK_EVENTS
|
events: CLICK_EVENTS,
|
||||||
|
// Wait for focus event, it guarantees us the submenu tree is created,
|
||||||
|
// that's necessary for next test.
|
||||||
|
eventSeq: [
|
||||||
|
new invokerChecker(EVENT_FOCUS, getNode("menu"))
|
||||||
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
ID: "submenu",
|
ID: "submenu",
|
||||||
|
@ -51,7 +51,6 @@ _TEST_FILES =\
|
|||||||
test_aria_globals.html \
|
test_aria_globals.html \
|
||||||
test_aria_imgmap.html \
|
test_aria_imgmap.html \
|
||||||
test_button.xul \
|
test_button.xul \
|
||||||
test_colorpicker.xul \
|
|
||||||
test_combobox.xul \
|
test_combobox.xul \
|
||||||
test_cssoverflow.html \
|
test_cssoverflow.html \
|
||||||
test_dochierarchy.html \
|
test_dochierarchy.html \
|
||||||
@ -65,7 +64,6 @@ _TEST_FILES =\
|
|||||||
test_img.html \
|
test_img.html \
|
||||||
test_list.html \
|
test_list.html \
|
||||||
test_media.html \
|
test_media.html \
|
||||||
test_menu.xul \
|
|
||||||
test_select.html \
|
test_select.html \
|
||||||
test_tabbox.xul \
|
test_tabbox.xul \
|
||||||
test_tabbrowser.xul \
|
test_tabbrowser.xul \
|
||||||
|
@ -24,7 +24,7 @@
|
|||||||
function doTest()
|
function doTest()
|
||||||
{
|
{
|
||||||
//////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////
|
||||||
// button1
|
// button
|
||||||
|
|
||||||
var accTree = {
|
var accTree = {
|
||||||
role: ROLE_PUSHBUTTON,
|
role: ROLE_PUSHBUTTON,
|
||||||
@ -34,112 +34,14 @@
|
|||||||
testAccessibleTree("button1", accTree);
|
testAccessibleTree("button1", accTree);
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////
|
||||||
// button2
|
// toolbarbutton
|
||||||
|
|
||||||
accTree = {
|
|
||||||
role: ROLE_PUSHBUTTON,
|
|
||||||
name: "hello",
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
role: ROLE_MENUPOPUP,
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
role: ROLE_MENUITEM
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: ROLE_MENUITEM
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
};
|
|
||||||
testAccessibleTree("button2", accTree);
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////
|
|
||||||
// button3
|
|
||||||
|
|
||||||
accTree = {
|
|
||||||
role: ROLE_PUSHBUTTON,
|
|
||||||
name: "hello",
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
role: ROLE_MENUPOPUP,
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
role: ROLE_MENUITEM
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: ROLE_MENUITEM
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: ROLE_PUSHBUTTON,
|
|
||||||
children: [
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
};
|
|
||||||
testAccessibleTree("button3", accTree);
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////
|
|
||||||
// button4
|
|
||||||
|
|
||||||
var accTree = {
|
var accTree = {
|
||||||
role: ROLE_PUSHBUTTON,
|
role: ROLE_PUSHBUTTON,
|
||||||
name: "hello",
|
name: "hello",
|
||||||
children: [ ]
|
children: [ ]
|
||||||
};
|
};
|
||||||
testAccessibleTree("button4", accTree);
|
testAccessibleTree("button2", accTree);
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////
|
|
||||||
// button5
|
|
||||||
|
|
||||||
accTree = {
|
|
||||||
role: ROLE_PUSHBUTTON,
|
|
||||||
name: "hello",
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
role: ROLE_MENUPOPUP,
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
role: ROLE_MENUITEM
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: ROLE_MENUITEM
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
};
|
|
||||||
testAccessibleTree("button5", accTree);
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////
|
|
||||||
// button6
|
|
||||||
|
|
||||||
accTree = {
|
|
||||||
role: ROLE_PUSHBUTTON,
|
|
||||||
name: "hello",
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
role: ROLE_MENUPOPUP,
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
role: ROLE_MENUITEM
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: ROLE_MENUITEM
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: ROLE_PUSHBUTTON,
|
|
||||||
children: [
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
};
|
|
||||||
testAccessibleTree("button6", accTree);
|
|
||||||
|
|
||||||
SimpleTest.finish()
|
SimpleTest.finish()
|
||||||
}
|
}
|
||||||
@ -165,32 +67,7 @@
|
|||||||
|
|
||||||
<vbox flex="1">
|
<vbox flex="1">
|
||||||
<button id="button1" label="hello"/>
|
<button id="button1" label="hello"/>
|
||||||
<button id="button2" type="menu" label="hello">
|
<toolbarbutton id="button2" label="hello"/>
|
||||||
<menupopup>
|
|
||||||
<menuitem label="menuitem"/>
|
|
||||||
<menuitem label="menuitem"/>
|
|
||||||
</menupopup>
|
|
||||||
</button>
|
|
||||||
<button id="button3" type="menu-button" label="hello">
|
|
||||||
<menupopup>
|
|
||||||
<menuitem label="menuitem"/>
|
|
||||||
<menuitem label="menuitem"/>
|
|
||||||
</menupopup>
|
|
||||||
</button>
|
|
||||||
|
|
||||||
<toolbarbutton id="button4" label="hello"/>
|
|
||||||
<toolbarbutton id="button5" type="menu" label="hello">
|
|
||||||
<menupopup>
|
|
||||||
<menuitem label="menuitem"/>
|
|
||||||
<menuitem label="menuitem"/>
|
|
||||||
</menupopup>
|
|
||||||
</toolbarbutton>
|
|
||||||
<toolbarbutton id="button6" type="menu-button" label="hello">
|
|
||||||
<menupopup>
|
|
||||||
<menuitem label="menuitem"/>
|
|
||||||
<menuitem label="menuitem"/>
|
|
||||||
</menupopup>
|
|
||||||
</toolbarbutton>
|
|
||||||
</vbox>
|
</vbox>
|
||||||
</hbox>
|
</hbox>
|
||||||
|
|
||||||
|
@ -1,75 +0,0 @@
|
|||||||
<?xml version="1.0"?>
|
|
||||||
<?xml-stylesheet href="chrome://global/skin" type="text/css"?>
|
|
||||||
<?xml-stylesheet href="chrome://mochikit/content/tests/SimpleTest/test.css"
|
|
||||||
type="text/css"?>
|
|
||||||
|
|
||||||
<window xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"
|
|
||||||
title="Accessible XUL button hierarchy tests">
|
|
||||||
|
|
||||||
<script type="application/javascript"
|
|
||||||
src="chrome://mochikit/content/MochiKit/packed.js" />
|
|
||||||
<script type="application/javascript"
|
|
||||||
src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js" />
|
|
||||||
|
|
||||||
<script type="application/javascript"
|
|
||||||
src="../common.js" />
|
|
||||||
<script type="application/javascript"
|
|
||||||
src="../role.js" />
|
|
||||||
|
|
||||||
<script type="application/javascript">
|
|
||||||
<![CDATA[
|
|
||||||
////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Test
|
|
||||||
|
|
||||||
function doTest()
|
|
||||||
{
|
|
||||||
//////////////////////////////////////////////////////////////////////////
|
|
||||||
// button1
|
|
||||||
|
|
||||||
var accTree = {
|
|
||||||
role: ROLE_BUTTONDROPDOWNGRID,
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
role: ROLE_ALERT,
|
|
||||||
children: [ ]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
};
|
|
||||||
|
|
||||||
var colorButtons = accTree.children[0].children;
|
|
||||||
for (var idx = 0; idx < 70; idx++) {
|
|
||||||
var obj = { role: ROLE_PUSHBUTTON };
|
|
||||||
colorButtons.push(obj);
|
|
||||||
}
|
|
||||||
|
|
||||||
testAccessibleTree("colorpicker", accTree);
|
|
||||||
|
|
||||||
SimpleTest.finish()
|
|
||||||
}
|
|
||||||
|
|
||||||
SimpleTest.waitForExplicitFinish();
|
|
||||||
addA11yLoadEvent(doTest);
|
|
||||||
]]>
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<hbox flex="1" style="overflow: auto;">
|
|
||||||
<body xmlns="http://www.w3.org/1999/xhtml">
|
|
||||||
<a target="_blank"
|
|
||||||
href="https://bugzilla.mozilla.org/show_bug.cgi?id=249292"
|
|
||||||
title="Ensure accessible children for toolbarbutton types 'menu' and 'menu-button'">
|
|
||||||
Mozilla Bug 249292
|
|
||||||
</a><br/>
|
|
||||||
<p id="display"></p>
|
|
||||||
<div id="content" style="display: none">
|
|
||||||
</div>
|
|
||||||
<pre id="test">
|
|
||||||
</pre>
|
|
||||||
</body>
|
|
||||||
|
|
||||||
<vbox flex="1">
|
|
||||||
<colorpicker id="colorpicker" type="button"/>
|
|
||||||
</vbox>
|
|
||||||
</hbox>
|
|
||||||
|
|
||||||
</window>
|
|
||||||
|
|
@ -1,86 +0,0 @@
|
|||||||
<?xml version="1.0"?>
|
|
||||||
<?xml-stylesheet href="chrome://global/skin" type="text/css"?>
|
|
||||||
<?xml-stylesheet href="chrome://mochikit/content/tests/SimpleTest/test.css"
|
|
||||||
type="text/css"?>
|
|
||||||
|
|
||||||
<window xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"
|
|
||||||
title="Accessible XUL menu hierarchy tests">
|
|
||||||
|
|
||||||
<script type="application/javascript"
|
|
||||||
src="chrome://mochikit/content/MochiKit/packed.js" />
|
|
||||||
<script type="application/javascript"
|
|
||||||
src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js" />
|
|
||||||
|
|
||||||
<script type="application/javascript"
|
|
||||||
src="../common.js" />
|
|
||||||
<script type="application/javascript"
|
|
||||||
src="../role.js" />
|
|
||||||
|
|
||||||
<script type="application/javascript">
|
|
||||||
<![CDATA[
|
|
||||||
////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Test
|
|
||||||
|
|
||||||
function doTest()
|
|
||||||
{
|
|
||||||
if (LINUX || SOLARIS) {
|
|
||||||
// XXX: bug 527646
|
|
||||||
|
|
||||||
todo(false, "Failure on Linux and Solaris.");
|
|
||||||
SimpleTest.finish();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var accTree = {
|
|
||||||
role: ROLE_PARENT_MENUITEM,
|
|
||||||
name: "menu",
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
role: ROLE_MENUPOPUP,
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
role: ROLE_MENUITEM
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: ROLE_MENUITEM
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
};
|
|
||||||
testAccessibleTree("menu", accTree);
|
|
||||||
|
|
||||||
SimpleTest.finish();
|
|
||||||
}
|
|
||||||
|
|
||||||
SimpleTest.waitForExplicitFinish();
|
|
||||||
addA11yLoadEvent(doTest);
|
|
||||||
]]>
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<hbox flex="1" style="overflow: auto;">
|
|
||||||
<body xmlns="http://www.w3.org/1999/xhtml">
|
|
||||||
<a target="_blank"
|
|
||||||
href="https://bugzilla.mozilla.org/show_bug.cgi?id=249292"
|
|
||||||
title="Ensure accessible children for toolbarbutton types 'menu' and 'menu-button'">
|
|
||||||
Mozilla Bug 249292
|
|
||||||
</a><br/>
|
|
||||||
<p id="display"></p>
|
|
||||||
<div id="content" style="display: none">
|
|
||||||
</div>
|
|
||||||
<pre id="test">
|
|
||||||
</pre>
|
|
||||||
</body>
|
|
||||||
|
|
||||||
<vbox flex="1">
|
|
||||||
<menu id="menu" label="menu">
|
|
||||||
<menupopup>
|
|
||||||
<menuitem label="menuitem"/>
|
|
||||||
<menuitem label="menuitem"/>
|
|
||||||
</menupopup>
|
|
||||||
</menu>
|
|
||||||
</vbox>
|
|
||||||
</hbox>
|
|
||||||
|
|
||||||
</window>
|
|
||||||
|
|
@ -47,11 +47,14 @@ include $(topsrcdir)/config/rules.mk
|
|||||||
|
|
||||||
_TEST_FILES =\
|
_TEST_FILES =\
|
||||||
test_ariadialog.html \
|
test_ariadialog.html \
|
||||||
|
test_colorpicker.xul \
|
||||||
|
test_contextmenu.xul \
|
||||||
test_doc.html \
|
test_doc.html \
|
||||||
test_gencontent.html \
|
test_gencontent.html \
|
||||||
test_list_editabledoc.html \
|
test_list_editabledoc.html \
|
||||||
test_list.html \
|
test_list.html \
|
||||||
test_menu.xul \
|
test_menu.xul \
|
||||||
|
test_menubutton.xul \
|
||||||
test_recreation.html \
|
test_recreation.html \
|
||||||
test_select.html \
|
test_select.html \
|
||||||
test_textleaf.html \
|
test_textleaf.html \
|
||||||
|
152
accessible/tests/mochitest/treeupdate/test_colorpicker.xul
Normal file
152
accessible/tests/mochitest/treeupdate/test_colorpicker.xul
Normal file
@ -0,0 +1,152 @@
|
|||||||
|
<?xml version="1.0"?>
|
||||||
|
<?xml-stylesheet href="chrome://global/skin" type="text/css"?>
|
||||||
|
<?xml-stylesheet href="chrome://mochikit/content/tests/SimpleTest/test.css"
|
||||||
|
type="text/css"?>
|
||||||
|
|
||||||
|
<window xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"
|
||||||
|
title="Accessible XUL button hierarchy tests">
|
||||||
|
|
||||||
|
<script type="application/javascript"
|
||||||
|
src="chrome://mochikit/content/MochiKit/packed.js" />
|
||||||
|
<script type="application/javascript"
|
||||||
|
src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js" />
|
||||||
|
|
||||||
|
<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[
|
||||||
|
////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Test
|
||||||
|
|
||||||
|
function openColorpicker(aColorpickerID)
|
||||||
|
{
|
||||||
|
this.node = getNode(aColorpickerID);
|
||||||
|
|
||||||
|
this.eventSeq = [];
|
||||||
|
|
||||||
|
var it = new colorButtonIterator(this.node);
|
||||||
|
for (var btnNode = it.next(); btnNode = it.next(); btnNode)
|
||||||
|
this.eventSeq.push(new invokerChecker(EVENT_SHOW, btnNode));
|
||||||
|
|
||||||
|
var popupNode = getPopupNode(this.node);
|
||||||
|
this.eventSeq.push(new invokerChecker(EVENT_REORDER, popupNode));
|
||||||
|
|
||||||
|
this.invoke = function openColorpicker_invoke()
|
||||||
|
{
|
||||||
|
var tree =
|
||||||
|
{ BUTTONDROPDOWNGRID: [
|
||||||
|
{ ALERT: [ ] }
|
||||||
|
] };
|
||||||
|
testAccessibleTree(this.node, tree);
|
||||||
|
|
||||||
|
this.node.showPopup();
|
||||||
|
}
|
||||||
|
|
||||||
|
this.finalCheck = function openColorpicker_finalCheck()
|
||||||
|
{
|
||||||
|
var tree =
|
||||||
|
{ BUTTONDROPDOWNGRID: [
|
||||||
|
{ ALERT: [ ] }
|
||||||
|
] };
|
||||||
|
|
||||||
|
var colorButtons = tree.BUTTONDROPDOWNGRID[0].ALERT;
|
||||||
|
var it = new colorButtonIterator(this.node);
|
||||||
|
while (it.next()) {
|
||||||
|
var obj = { PUSHBUTTON: [ ] };
|
||||||
|
colorButtons.push(obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
testAccessibleTree(this.node, tree);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.getID = function openColorpicker_getID()
|
||||||
|
{
|
||||||
|
return "open colorpicker " + prettyName(aColorpickerID);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function getPopupNode(aColorpickerNode)
|
||||||
|
{
|
||||||
|
return aColorpickerNode.mPicker.parentNode;
|
||||||
|
}
|
||||||
|
|
||||||
|
function colorButtonIterator(aColorpickerNode)
|
||||||
|
{
|
||||||
|
this.container = aColorpickerNode.mPicker.mBox;
|
||||||
|
this.group = this.container.firstChild;
|
||||||
|
this.item = null;
|
||||||
|
|
||||||
|
this.next = function colorButtonIterator_next()
|
||||||
|
{
|
||||||
|
if (!this.group)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
if (!this.item) {
|
||||||
|
this.item = this.group.firstChild;
|
||||||
|
return this.item;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.item.nextSibling) {
|
||||||
|
this.item = this.item.nextSibling;
|
||||||
|
return this.item;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.group.nextSibling) {
|
||||||
|
this.group = this.group.nextSibling;
|
||||||
|
this.item = this.group.firstChild;
|
||||||
|
return this.item;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.group = null;
|
||||||
|
this.item = null;
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//gA11yEventDumpToConsole = true; // debug stuff
|
||||||
|
|
||||||
|
var gQueue = null;
|
||||||
|
function doTest()
|
||||||
|
{
|
||||||
|
gQueue = new eventQueue();
|
||||||
|
gQueue.push(new openColorpicker("colorpicker"));
|
||||||
|
gQueue.invoke(); // Will call SimpleTest.finish()
|
||||||
|
}
|
||||||
|
|
||||||
|
SimpleTest.waitForExplicitFinish();
|
||||||
|
addA11yLoadEvent(doTest);
|
||||||
|
]]>
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<hbox flex="1" style="overflow: auto;">
|
||||||
|
<body xmlns="http://www.w3.org/1999/xhtml">
|
||||||
|
<a target="_blank"
|
||||||
|
href="https://bugzilla.mozilla.org/show_bug.cgi?id=249292"
|
||||||
|
title="Ensure accessible children for toolbarbutton types 'menu' and 'menu-button'">
|
||||||
|
Mozilla Bug 249292
|
||||||
|
</a>
|
||||||
|
<a target="_blank"
|
||||||
|
href="https://bugzilla.mozilla.org/show_bug.cgi?id=630486"
|
||||||
|
title="Don't force accessible creation for popup children.">
|
||||||
|
Mozilla Bug 630486
|
||||||
|
</a>
|
||||||
|
<br/>
|
||||||
|
<p id="display"></p>
|
||||||
|
<div id="content" style="display: none">
|
||||||
|
</div>
|
||||||
|
<pre id="test">
|
||||||
|
</pre>
|
||||||
|
</body>
|
||||||
|
|
||||||
|
<vbox flex="1">
|
||||||
|
<colorpicker id="colorpicker" type="button"/>
|
||||||
|
</vbox>
|
||||||
|
</hbox>
|
||||||
|
|
||||||
|
</window>
|
||||||
|
|
321
accessible/tests/mochitest/treeupdate/test_contextmenu.xul
Normal file
321
accessible/tests/mochitest/treeupdate/test_contextmenu.xul
Normal file
@ -0,0 +1,321 @@
|
|||||||
|
<?xml version="1.0"?>
|
||||||
|
<?xml-stylesheet href="chrome://global/skin" type="text/css"?>
|
||||||
|
<?xml-stylesheet href="chrome://mochikit/content/tests/SimpleTest/test.css"
|
||||||
|
type="text/css"?>
|
||||||
|
|
||||||
|
<window xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"
|
||||||
|
title="menu tree and events">
|
||||||
|
|
||||||
|
<script type="application/javascript"
|
||||||
|
src="chrome://mochikit/content/MochiKit/packed.js" />
|
||||||
|
<script type="application/javascript"
|
||||||
|
src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js" />
|
||||||
|
<script type="application/javascript"
|
||||||
|
src="chrome://mochikit/content/tests/SimpleTest/EventUtils.js"/>
|
||||||
|
|
||||||
|
<script type="application/javascript"
|
||||||
|
src="../common.js" />
|
||||||
|
<script type="application/javascript"
|
||||||
|
src="../events.js" />
|
||||||
|
<script type="application/javascript"
|
||||||
|
src="../role.js" />
|
||||||
|
|
||||||
|
<script type="application/javascript">
|
||||||
|
<![CDATA[
|
||||||
|
|
||||||
|
function openMenu(aID, aTree)
|
||||||
|
{
|
||||||
|
this.eventSeq = [
|
||||||
|
new invokerChecker(EVENT_MENUPOPUP_START, getNode(aID))
|
||||||
|
];
|
||||||
|
|
||||||
|
this.invoke = function openMenu_invoke()
|
||||||
|
{
|
||||||
|
var button = getNode("button");
|
||||||
|
getNode(aID).openPopup(button, "after_start", 0, 0, true, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.finalCheck = function openMenu_finalCheck(aEvent)
|
||||||
|
{
|
||||||
|
testAccessibleTree(aID, aTree);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.getID = function openMenu_getID()
|
||||||
|
{
|
||||||
|
return "open menu " + prettyName(aID);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function selectNextMenuItem(aID)
|
||||||
|
{
|
||||||
|
this.eventSeq = [
|
||||||
|
new invokerChecker(EVENT_FOCUS, getNode(aID))
|
||||||
|
];
|
||||||
|
|
||||||
|
this.invoke = function selectMenuItem_invoke()
|
||||||
|
{
|
||||||
|
synthesizeKey("VK_DOWN", { });
|
||||||
|
}
|
||||||
|
|
||||||
|
this.getID = function selectMenuItem_getID()
|
||||||
|
{
|
||||||
|
return "select menuitem " + prettyName(aID);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function openSubMenu(aSubMenuID, aItemID, aMenuID, aTree)
|
||||||
|
{
|
||||||
|
this.eventSeq = [
|
||||||
|
new invokerChecker(EVENT_FOCUS, getNode(aItemID)),
|
||||||
|
];
|
||||||
|
|
||||||
|
this.invoke = function openSubMenu_invoke()
|
||||||
|
{
|
||||||
|
synthesizeKey("VK_ENTER", { });
|
||||||
|
}
|
||||||
|
|
||||||
|
this.finalCheck = function openSubMenu_finalCheck(aEvent)
|
||||||
|
{
|
||||||
|
testAccessibleTree(aMenuID, aTree);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.getID = function openSubMenu_getID()
|
||||||
|
{
|
||||||
|
return "open submenu " + prettyName(aSubMenuID) + " focusing item " + prettyName(aItemID);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function closeSubMenu(aSubMenuID, aItemID)
|
||||||
|
{
|
||||||
|
this.eventSeq = [
|
||||||
|
new invokerChecker(EVENT_FOCUS, getNode(aItemID)),
|
||||||
|
];
|
||||||
|
|
||||||
|
this.invoke = function closeSubMenu_invoke()
|
||||||
|
{
|
||||||
|
synthesizeKey("VK_ESCAPE", { });
|
||||||
|
}
|
||||||
|
|
||||||
|
this.getID = function closeSubMenu_getID()
|
||||||
|
{
|
||||||
|
return "close submenu " + prettyName(aSubMenuID) + " focusing item " + prettyName(aItemID);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function closeMenu(aID)
|
||||||
|
{
|
||||||
|
this.eventSeq = [
|
||||||
|
new invokerChecker(EVENT_MENUPOPUP_END, getNode(aID))
|
||||||
|
];
|
||||||
|
|
||||||
|
this.invoke = function closeMenu_invoke()
|
||||||
|
{
|
||||||
|
synthesizeKey("VK_ESCAPE", { });
|
||||||
|
}
|
||||||
|
|
||||||
|
this.getID = function closeMenu_getID()
|
||||||
|
{
|
||||||
|
return "close menu " + prettyName(aID);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//gA11yEventDumpID = "eventdump";
|
||||||
|
//gA11yEventDumpToConsole = true;
|
||||||
|
|
||||||
|
var gQueue = null;
|
||||||
|
var gContextTree = {};
|
||||||
|
|
||||||
|
// Linux and Windows menu trees discrepancy: bug 527646.
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the context menu tree before submenus were open.
|
||||||
|
*/
|
||||||
|
function getMenuTree1()
|
||||||
|
{
|
||||||
|
if (LINUX || SOLARIS) {
|
||||||
|
var tree = {
|
||||||
|
role: ROLE_MENUPOPUP,
|
||||||
|
children: [
|
||||||
|
{
|
||||||
|
name: "item0",
|
||||||
|
role: ROLE_MENUITEM,
|
||||||
|
children: []
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "item1",
|
||||||
|
role: ROLE_MENUITEM,
|
||||||
|
children: []
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "item2",
|
||||||
|
role: ROLE_PARENT_MENUITEM,
|
||||||
|
children: [ ]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
return tree;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Windows
|
||||||
|
var tree = {
|
||||||
|
role: ROLE_MENUPOPUP,
|
||||||
|
children: [
|
||||||
|
{
|
||||||
|
name: "item0",
|
||||||
|
role: ROLE_MENUITEM,
|
||||||
|
children: []
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "item1",
|
||||||
|
role: ROLE_MENUITEM,
|
||||||
|
children: []
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "item2",
|
||||||
|
role: ROLE_PARENT_MENUITEM,
|
||||||
|
children: [
|
||||||
|
{
|
||||||
|
name: "item2",
|
||||||
|
role: ROLE_MENUPOPUP,
|
||||||
|
children: [ ]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
return tree;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return context menu tree when submenu was open.
|
||||||
|
*/
|
||||||
|
function getMenuTree2()
|
||||||
|
{
|
||||||
|
var tree = getMenuTree1();
|
||||||
|
if (LINUX || SOLARIS) {
|
||||||
|
var submenuTree =
|
||||||
|
{
|
||||||
|
name: "item2.0",
|
||||||
|
role: ROLE_PARENT_MENUITEM,
|
||||||
|
children: [ ]
|
||||||
|
};
|
||||||
|
tree.children[2].children.push(submenuTree);
|
||||||
|
return tree;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Windows
|
||||||
|
var submenuTree =
|
||||||
|
{
|
||||||
|
name: "item2.0",
|
||||||
|
role: ROLE_PARENT_MENUITEM,
|
||||||
|
children: [
|
||||||
|
{
|
||||||
|
name: "item2.0",
|
||||||
|
role: ROLE_MENUPOPUP,
|
||||||
|
children: [ ]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
|
||||||
|
tree.children[2].children[0].children.push(submenuTree);
|
||||||
|
return tree;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return context menu tree when subsub menu was open.
|
||||||
|
*/
|
||||||
|
function getMenuTree3()
|
||||||
|
{
|
||||||
|
var tree = getMenuTree2();
|
||||||
|
var subsubmenuTree =
|
||||||
|
{
|
||||||
|
name: "item2.0.0",
|
||||||
|
role: ROLE_MENUITEM,
|
||||||
|
children: []
|
||||||
|
};
|
||||||
|
|
||||||
|
if (LINUX || SOLARIS)
|
||||||
|
tree.children[2].children[0].\(subsubmenuTree);
|
||||||
|
else
|
||||||
|
tree.children[2].children[0].children[0].children[0].children.push(subsubmenuTree);
|
||||||
|
|
||||||
|
return tree;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function doTests()
|
||||||
|
{
|
||||||
|
gQueue = new eventQueue();
|
||||||
|
|
||||||
|
// Check initial empty tree
|
||||||
|
testAccessibleTree("context", { MENUPOPUP: [] });
|
||||||
|
|
||||||
|
// Open context menu and check that menu item accesibles are created.
|
||||||
|
gQueue.push(new openMenu("context", getMenuTree1()));
|
||||||
|
|
||||||
|
// Select items and check focus event on them.
|
||||||
|
gQueue.push(new selectNextMenuItem("item0"));
|
||||||
|
gQueue.push(new selectNextMenuItem("item1"));
|
||||||
|
gQueue.push(new selectNextMenuItem("item2"));
|
||||||
|
|
||||||
|
// Open sub menu and check menu accessible tree and focus event.
|
||||||
|
gQueue.push(new openSubMenu("submenu2", "item2.0",
|
||||||
|
"context", getMenuTree2()));
|
||||||
|
gQueue.push(new openSubMenu("submenu2.0", "item2.0.0",
|
||||||
|
"context", getMenuTree3()));
|
||||||
|
|
||||||
|
// Close submenus and check that focus goes to parent.
|
||||||
|
gQueue.push(new closeSubMenu("submenu2.0", "item2.0"));
|
||||||
|
gQueue.push(new closeSubMenu("submenu2", "item2"));
|
||||||
|
|
||||||
|
gQueue.push(new closeMenu("context"));
|
||||||
|
|
||||||
|
gQueue.invoke(); // Will call SimpleTest.finish();
|
||||||
|
}
|
||||||
|
|
||||||
|
SimpleTest.waitForExplicitFinish();
|
||||||
|
addA11yLoadEvent(doTests);
|
||||||
|
]]>
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<hbox flex="1" style="overflow: auto;">
|
||||||
|
<body xmlns="http://www.w3.org/1999/xhtml">
|
||||||
|
<a target="_blank"
|
||||||
|
href="https://bugzilla.mozilla.org/show_bug.cgi?id=630194"
|
||||||
|
title="Update accessible tree when opening the menu popup">
|
||||||
|
Mozilla Bug 630194
|
||||||
|
</a>
|
||||||
|
<a target="_blank"
|
||||||
|
href="https://bugzilla.mozilla.org/show_bug.cgi?id=630486"
|
||||||
|
title="Don't force accessible creation for popup children.">
|
||||||
|
Mozilla Bug 630486
|
||||||
|
</a>
|
||||||
|
<p id="display"></p>
|
||||||
|
<div id="content" style="display: none">
|
||||||
|
</div>
|
||||||
|
<pre id="test">
|
||||||
|
</pre>
|
||||||
|
</body>
|
||||||
|
|
||||||
|
<vbox flex="1">
|
||||||
|
|
||||||
|
<menupopup id="context">
|
||||||
|
<menuitem id="item0" label="item0"/>
|
||||||
|
<menuitem id="item1" label="item1"/>
|
||||||
|
<menu id="item2" label="item2">
|
||||||
|
<menupopup id="submenu2">
|
||||||
|
<menu id="item2.0" label="item2.0">
|
||||||
|
<menupopup id="submenu2.0">
|
||||||
|
<menuitem id="item2.0.0" label="item2.0.0"/>
|
||||||
|
</menupopup>
|
||||||
|
</menu>
|
||||||
|
</menupopup>
|
||||||
|
</menu>
|
||||||
|
</menupopup>
|
||||||
|
|
||||||
|
<button context="context" id="button">btn</button>
|
||||||
|
|
||||||
|
<vbox id="eventdump" role="log"/>
|
||||||
|
</vbox>
|
||||||
|
</hbox>
|
||||||
|
</window>
|
@ -4,39 +4,72 @@
|
|||||||
type="text/css"?>
|
type="text/css"?>
|
||||||
|
|
||||||
<window xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"
|
<window xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"
|
||||||
title="menu tree and events">
|
title="Accessible XUL menu hierarchy tests">
|
||||||
|
|
||||||
<script type="application/javascript"
|
<script type="application/javascript"
|
||||||
src="chrome://mochikit/content/MochiKit/packed.js" />
|
src="chrome://mochikit/content/MochiKit/packed.js" />
|
||||||
<script type="application/javascript"
|
<script type="application/javascript"
|
||||||
src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js" />
|
src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js" />
|
||||||
<script type="application/javascript"
|
|
||||||
src="chrome://mochikit/content/tests/SimpleTest/EventUtils.js"/>
|
|
||||||
|
|
||||||
<script type="application/javascript"
|
<script type="application/javascript"
|
||||||
src="../common.js" />
|
src="../common.js" />
|
||||||
<script type="application/javascript"
|
|
||||||
src="../events.js" />
|
|
||||||
<script type="application/javascript"
|
<script type="application/javascript"
|
||||||
src="../role.js" />
|
src="../role.js" />
|
||||||
|
<script type="application/javascript"
|
||||||
|
src="../events.js" />
|
||||||
|
|
||||||
<script type="application/javascript">
|
<script type="application/javascript">
|
||||||
<![CDATA[
|
<![CDATA[
|
||||||
function openMenu(aID, aTree)
|
////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Invokers
|
||||||
|
|
||||||
|
function openMenu(aID)
|
||||||
{
|
{
|
||||||
|
this.menuNode = getNode(aID),
|
||||||
|
|
||||||
this.eventSeq = [
|
this.eventSeq = [
|
||||||
new invokerChecker(EVENT_MENUPOPUP_START, getNode(aID))
|
new invokerChecker(EVENT_FOCUS, this.menuNode)
|
||||||
];
|
];
|
||||||
|
|
||||||
this.invoke = function openMenu_invoke()
|
this.invoke = function openMenu_invoke()
|
||||||
{
|
{
|
||||||
var button = getNode("button");
|
var tree;
|
||||||
getNode(aID).openPopup(button, "after_start", 0, 0, true, false);
|
if (LINUX || SOLARIS) {
|
||||||
|
tree =
|
||||||
|
{ PARENT_MENUITEM: [ ] };
|
||||||
|
|
||||||
|
} else {
|
||||||
|
tree =
|
||||||
|
{ PARENT_MENUITEM: [
|
||||||
|
{ MENUPOPUP: [ ] }
|
||||||
|
] };
|
||||||
|
}
|
||||||
|
testAccessibleTree(aID, tree);
|
||||||
|
|
||||||
|
// Show menu.
|
||||||
|
this.menuNode.open = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.finalCheck = function openMenu_finalCheck(aEvent)
|
this.finalCheck = function openMenu_finalCheck()
|
||||||
{
|
{
|
||||||
testAccessibleTree(aID, aTree);
|
var tree;
|
||||||
|
if (LINUX || SOLARIS) {
|
||||||
|
tree =
|
||||||
|
{ PARENT_MENUITEM: [
|
||||||
|
{ MENUITEM: [ ] },
|
||||||
|
{ MENUITEM: [ ] }
|
||||||
|
] };
|
||||||
|
|
||||||
|
} else {
|
||||||
|
tree =
|
||||||
|
{ PARENT_MENUITEM: [
|
||||||
|
{ MENUPOPUP: [
|
||||||
|
{ MENUITEM: [ ] },
|
||||||
|
{ MENUITEM: [ ] }
|
||||||
|
] }
|
||||||
|
] };
|
||||||
|
}
|
||||||
|
testAccessibleTree(aID, tree);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.getID = function openMenu_getID()
|
this.getID = function openMenu_getID()
|
||||||
@ -45,233 +78,53 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function selectNextMenuItem(aID)
|
////////////////////////////////////////////////////////////////////////////
|
||||||
{
|
// Test
|
||||||
this.eventSeq = [
|
|
||||||
new invokerChecker(EVENT_FOCUS, getNode(aID))
|
|
||||||
];
|
|
||||||
|
|
||||||
this.invoke = function selectMenuItem_invoke()
|
|
||||||
{
|
|
||||||
synthesizeKey("VK_DOWN", { });
|
|
||||||
}
|
|
||||||
|
|
||||||
this.getID = function selectMenuItem_getID()
|
|
||||||
{
|
|
||||||
return "select menuitem " + prettyName(aID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function openSubMenu(aSubMenuID, aItemID)
|
|
||||||
{
|
|
||||||
this.eventSeq = [
|
|
||||||
new invokerChecker(EVENT_FOCUS, getNode(aItemID)),
|
|
||||||
];
|
|
||||||
|
|
||||||
this.invoke = function openSubMenu_invoke()
|
|
||||||
{
|
|
||||||
synthesizeKey("VK_ENTER", { });
|
|
||||||
}
|
|
||||||
|
|
||||||
this.finalCheck = function openSubMenu_finalCheck(aEvent)
|
|
||||||
{
|
|
||||||
getAccessible(aItemID);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.getID = function openSubMenu_getID()
|
|
||||||
{
|
|
||||||
return "open submenu " + prettyName(aSubMenuID) + " focusing item " + prettyName(aItemID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function closeSubMenu(aSubMenuID, aItemID)
|
|
||||||
{
|
|
||||||
this.eventSeq = [
|
|
||||||
new invokerChecker(EVENT_FOCUS, getNode(aItemID)),
|
|
||||||
];
|
|
||||||
|
|
||||||
this.invoke = function closeSubMenu_invoke()
|
|
||||||
{
|
|
||||||
synthesizeKey("VK_ESCAPE", { });
|
|
||||||
}
|
|
||||||
|
|
||||||
this.getID = function closeSubMenu_getID()
|
|
||||||
{
|
|
||||||
return "close submenu " + prettyName(aSubMenuID) + " focusing item " + prettyName(aItemID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function closeMenu(aID)
|
|
||||||
{
|
|
||||||
this.eventSeq = [
|
|
||||||
new invokerChecker(EVENT_MENUPOPUP_END, getNode(aID))
|
|
||||||
];
|
|
||||||
|
|
||||||
this.invoke = function closeMenu_invoke()
|
|
||||||
{
|
|
||||||
synthesizeKey("VK_ESCAPE", { });
|
|
||||||
}
|
|
||||||
|
|
||||||
this.getID = function closeMenu_getID()
|
|
||||||
{
|
|
||||||
return "close menu " + prettyName(aID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//gA11yEventDumpID = "eventdump";
|
|
||||||
//gA11yEventDumpToConsole = true;
|
|
||||||
|
|
||||||
var gQueue = null;
|
var gQueue = null;
|
||||||
var gContextTree = {};
|
function doTest()
|
||||||
|
|
||||||
// bug 527646
|
|
||||||
if (LINUX || SOLARIS) {
|
|
||||||
gContextTree = {
|
|
||||||
role: ROLE_MENUPOPUP,
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
name: "item0",
|
|
||||||
role: ROLE_MENUITEM,
|
|
||||||
children: []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: "item1",
|
|
||||||
role: ROLE_MENUITEM,
|
|
||||||
children: []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: "item2",
|
|
||||||
role: ROLE_PARENT_MENUITEM,
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
name: "item2.0",
|
|
||||||
role: ROLE_PARENT_MENUITEM,
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
name: "item2.0.0",
|
|
||||||
role: ROLE_MENUITEM,
|
|
||||||
children: []
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
};
|
|
||||||
} else {
|
|
||||||
gContextTree = {
|
|
||||||
role: ROLE_MENUPOPUP,
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
name: "item0",
|
|
||||||
role: ROLE_MENUITEM,
|
|
||||||
children: []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: "item1",
|
|
||||||
role: ROLE_MENUITEM,
|
|
||||||
children: []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: "item2",
|
|
||||||
role: ROLE_PARENT_MENUITEM,
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
name: "item2",
|
|
||||||
role: ROLE_MENUPOPUP,
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
name: "item2.0",
|
|
||||||
role: ROLE_PARENT_MENUITEM,
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
name: "item2.0",
|
|
||||||
role: ROLE_MENUPOPUP,
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
name: "item2.0.0",
|
|
||||||
role: ROLE_MENUITEM,
|
|
||||||
children: []
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function doTests()
|
|
||||||
{
|
{
|
||||||
gQueue = new eventQueue();
|
gQueue = new eventQueue();
|
||||||
|
gQueue.push(new openMenu("menu"));
|
||||||
// Check initial empty tree
|
|
||||||
testAccessibleTree("context", { MENUPOPUP: [] });
|
|
||||||
|
|
||||||
// Open context menu and check that menu item accesibles are created.
|
|
||||||
gQueue.push(new openMenu("context", gContextTree));
|
|
||||||
|
|
||||||
// Select items and check focus event on them.
|
|
||||||
gQueue.push(new selectNextMenuItem("item0"));
|
|
||||||
gQueue.push(new selectNextMenuItem("item1"));
|
|
||||||
gQueue.push(new selectNextMenuItem("item2"));
|
|
||||||
|
|
||||||
// Open sub menu and check menu item accessibles and focus event.
|
|
||||||
gQueue.push(new openSubMenu("submenu2", "item2.0"));
|
|
||||||
gQueue.push(new openSubMenu("submenu2.0", "item2.0.0"));
|
|
||||||
|
|
||||||
// Close submenus and check that focus goes to parent.
|
|
||||||
gQueue.push(new closeSubMenu("submenu2.0", "item2.0"));
|
|
||||||
gQueue.push(new closeSubMenu("submenu2", "item2"));
|
|
||||||
|
|
||||||
gQueue.push(new closeMenu("context"));
|
|
||||||
|
|
||||||
gQueue.invoke(); // Will call SimpleTest.finish();
|
gQueue.invoke(); // Will call SimpleTest.finish();
|
||||||
}
|
}
|
||||||
|
|
||||||
SimpleTest.waitForExplicitFinish();
|
SimpleTest.waitForExplicitFinish();
|
||||||
addA11yLoadEvent(doTests);
|
addA11yLoadEvent(doTest);
|
||||||
]]>
|
]]>
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<hbox flex="1" style="overflow: auto;">
|
<hbox flex="1" style="overflow: auto;">
|
||||||
<body xmlns="http://www.w3.org/1999/xhtml">
|
<body xmlns="http://www.w3.org/1999/xhtml">
|
||||||
<a target="_blank"
|
<a target="_blank"
|
||||||
href="https://bugzilla.mozilla.org/show_bug.cgi?id=630194"
|
href="https://bugzilla.mozilla.org/show_bug.cgi?id=249292"
|
||||||
title="Update accessible tree when opening the menu popup">
|
title="Ensure accessible children for toolbarbutton types 'menu' and 'menu-button'">
|
||||||
Mozilla Bug 630194
|
Mozilla Bug 249292
|
||||||
</a>
|
</a>
|
||||||
<p id="display"></p>
|
<a target="_blank"
|
||||||
<div id="content" style="display: none">
|
href="https://bugzilla.mozilla.org/show_bug.cgi?id=630486"
|
||||||
</div>
|
title="Don't force accessible creation for popup children.">
|
||||||
<pre id="test">
|
Mozilla Bug 630486
|
||||||
</pre>
|
</a>
|
||||||
</body>
|
<br/>
|
||||||
|
<p id="display"></p>
|
||||||
|
<div id="content" style="display: none">
|
||||||
|
</div>
|
||||||
|
<pre id="test">
|
||||||
|
</pre>
|
||||||
|
</body>
|
||||||
|
|
||||||
<vbox flex="1">
|
<vbox flex="1">
|
||||||
|
<menubar>
|
||||||
<menupopup id="context">
|
<menu id="menu" label="menu">
|
||||||
<menuitem id="item0" label="item0"/>
|
<menupopup>
|
||||||
<menuitem id="item1" label="item1"/>
|
<menuitem label="menuitem"/>
|
||||||
<menu id="item2" label="item2">
|
<menuitem label="menuitem"/>
|
||||||
<menupopup id="submenu2">
|
|
||||||
<menu id="item2.0" label="item2.0">
|
|
||||||
<menupopup id="submenu2.0">
|
|
||||||
<menuitem id="item2.0.0" label="item2.0.0"/>
|
|
||||||
</menupopup>
|
|
||||||
</menu>
|
|
||||||
</menupopup>
|
</menupopup>
|
||||||
</menu>
|
</menu>
|
||||||
</menupopup>
|
</menubar>
|
||||||
|
|
||||||
<button context="context" id="button">btn</button>
|
|
||||||
|
|
||||||
<vbox id="eventdump" role="log"/>
|
|
||||||
</vbox>
|
</vbox>
|
||||||
</hbox>
|
</hbox>
|
||||||
|
|
||||||
</window>
|
</window>
|
||||||
|
|
||||||
|
179
accessible/tests/mochitest/treeupdate/test_menubutton.xul
Normal file
179
accessible/tests/mochitest/treeupdate/test_menubutton.xul
Normal file
@ -0,0 +1,179 @@
|
|||||||
|
<?xml version="1.0"?>
|
||||||
|
<?xml-stylesheet href="chrome://global/skin" type="text/css"?>
|
||||||
|
<?xml-stylesheet href="chrome://mochikit/content/tests/SimpleTest/test.css"
|
||||||
|
type="text/css"?>
|
||||||
|
|
||||||
|
<window xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"
|
||||||
|
title="Accessible XUL button hierarchy tests">
|
||||||
|
|
||||||
|
<script type="application/javascript"
|
||||||
|
src="chrome://mochikit/content/MochiKit/packed.js" />
|
||||||
|
<script type="application/javascript"
|
||||||
|
src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js" />
|
||||||
|
|
||||||
|
<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)
|
||||||
|
{
|
||||||
|
this.buttonNode = getNode(aButtonID);
|
||||||
|
this.menupoupNode = this.buttonNode.firstChild;
|
||||||
|
|
||||||
|
this.eventSeq = [
|
||||||
|
new invokerChecker(EVENT_REORDER, this.menupoupNode)
|
||||||
|
];
|
||||||
|
|
||||||
|
this.invoke = function openMenu_invoke()
|
||||||
|
{
|
||||||
|
var tree =
|
||||||
|
{ PUSHBUTTON: [
|
||||||
|
{ MENUPOPUP: [ ] }
|
||||||
|
] };
|
||||||
|
testAccessibleTree(this.buttonNode, tree);
|
||||||
|
|
||||||
|
this.buttonNode.open = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.finalCheck = function openMenu_finalCheck()
|
||||||
|
{
|
||||||
|
var tree =
|
||||||
|
{ PUSHBUTTON: [
|
||||||
|
{ MENUPOPUP: [
|
||||||
|
{ MENUITEM: [ ] },
|
||||||
|
{ MENUITEM: [ ] }
|
||||||
|
] }
|
||||||
|
] };
|
||||||
|
testAccessibleTree(this.buttonNode, tree);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.getID = function openMenu_getID()
|
||||||
|
{
|
||||||
|
return "open menu for button " + prettyName(aButtonID);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function openMenuButton(aButtonID)
|
||||||
|
{
|
||||||
|
this.buttonNode = getNode(aButtonID);
|
||||||
|
this.menupoupNode = this.buttonNode.firstChild;
|
||||||
|
|
||||||
|
this.eventSeq = [
|
||||||
|
new invokerChecker(EVENT_REORDER, this.menupoupNode)
|
||||||
|
];
|
||||||
|
|
||||||
|
this.invoke = function openMenu_invoke()
|
||||||
|
{
|
||||||
|
var tree =
|
||||||
|
{ PUSHBUTTON: [
|
||||||
|
{ MENUPOPUP: [ ] },
|
||||||
|
{ PUSHBUTTON: [ ] }
|
||||||
|
] };
|
||||||
|
testAccessibleTree(this.buttonNode, tree);
|
||||||
|
|
||||||
|
this.buttonNode.open = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.finalCheck = function openMenu_finalCheck()
|
||||||
|
{
|
||||||
|
var tree =
|
||||||
|
{ PUSHBUTTON: [
|
||||||
|
{ MENUPOPUP: [
|
||||||
|
{ MENUITEM: [ ] },
|
||||||
|
{ MENUITEM: [ ] }
|
||||||
|
] },
|
||||||
|
{ PUSHBUTTON: [ ] }
|
||||||
|
] };
|
||||||
|
testAccessibleTree(this.buttonNode, tree);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.getID = function openMenu_getID()
|
||||||
|
{
|
||||||
|
return "open menu for menu 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 openMenuButton("button2"));
|
||||||
|
gQueue.push(new openMenu("button3"));
|
||||||
|
gQueue.push(new openMenuButton("button4"));
|
||||||
|
|
||||||
|
gQueue.invoke(); // SimpleTest.finish()
|
||||||
|
}
|
||||||
|
|
||||||
|
SimpleTest.waitForExplicitFinish();
|
||||||
|
addA11yLoadEvent(doTest);
|
||||||
|
]]>
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<hbox flex="1" style="overflow: auto;">
|
||||||
|
<body xmlns="http://www.w3.org/1999/xhtml">
|
||||||
|
<a target="_blank"
|
||||||
|
href="https://bugzilla.mozilla.org/show_bug.cgi?id=249292"
|
||||||
|
title="Ensure accessible children for toolbarbutton types 'menu' and 'menu-button'">
|
||||||
|
Mozilla Bug 249292
|
||||||
|
</a>
|
||||||
|
<a target="_blank"
|
||||||
|
href="https://bugzilla.mozilla.org/show_bug.cgi?id=630486"
|
||||||
|
title="Don't force accessible creation for popup children.">
|
||||||
|
Mozilla Bug 630486
|
||||||
|
</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="hello">
|
||||||
|
<menupopup>
|
||||||
|
<menuitem label="menuitem"/>
|
||||||
|
<menuitem label="menuitem"/>
|
||||||
|
</menupopup>
|
||||||
|
</button>
|
||||||
|
<button id="button2" type="menu-button" label="hello">
|
||||||
|
<menupopup>
|
||||||
|
<menuitem label="menuitem"/>
|
||||||
|
<menuitem label="menuitem"/>
|
||||||
|
</menupopup>
|
||||||
|
</button>
|
||||||
|
|
||||||
|
<toolbarbutton id="button3" type="menu" label="hello">
|
||||||
|
<menupopup>
|
||||||
|
<menuitem label="menuitem"/>
|
||||||
|
<menuitem label="menuitem"/>
|
||||||
|
</menupopup>
|
||||||
|
</toolbarbutton>
|
||||||
|
<toolbarbutton id="button4" type="menu-button" label="hello">
|
||||||
|
<menupopup>
|
||||||
|
<menuitem label="menuitem"/>
|
||||||
|
<menuitem label="menuitem"/>
|
||||||
|
</menupopup>
|
||||||
|
</toolbarbutton>
|
||||||
|
</vbox>
|
||||||
|
</hbox>
|
||||||
|
|
||||||
|
</window>
|
||||||
|
|
@ -49,7 +49,7 @@
|
|||||||
<xul:hbox align="center">
|
<xul:hbox align="center">
|
||||||
<xul:description anonid="subscribeUsingDescription" class="subscribeUsingDescription"/>
|
<xul:description anonid="subscribeUsingDescription" class="subscribeUsingDescription"/>
|
||||||
<xul:menulist anonid="handlersMenuList" class="handlersMenuList" aria-labelledby="subscribeUsingDescription">
|
<xul:menulist anonid="handlersMenuList" class="handlersMenuList" aria-labelledby="subscribeUsingDescription">
|
||||||
<xul:menupopup menugenerated="true" anonid="handlersMenuPopup" class="handlersMenuPopup">
|
<xul:menupopup anonid="handlersMenuPopup" class="handlersMenuPopup">
|
||||||
<xul:menuitem anonid="liveBookmarksMenuItem" label="&feedLiveBookmarks;" class="menuitem-iconic liveBookmarksMenuItem" image="chrome://browser/skin/page-livemarks.png" selected="true"/>
|
<xul:menuitem anonid="liveBookmarksMenuItem" label="&feedLiveBookmarks;" class="menuitem-iconic liveBookmarksMenuItem" image="chrome://browser/skin/page-livemarks.png" selected="true"/>
|
||||||
<xul:menuseparator/>
|
<xul:menuseparator/>
|
||||||
</xul:menupopup>
|
</xul:menupopup>
|
||||||
|
@ -561,7 +561,6 @@ GK_ATOM(menu, "menu")
|
|||||||
GK_ATOM(menubar, "menubar")
|
GK_ATOM(menubar, "menubar")
|
||||||
GK_ATOM(menubutton, "menubutton")
|
GK_ATOM(menubutton, "menubutton")
|
||||||
GK_ATOM(menuButton, "menu-button")
|
GK_ATOM(menuButton, "menu-button")
|
||||||
GK_ATOM(menugenerated, "menugenerated")
|
|
||||||
GK_ATOM(menuitem, "menuitem")
|
GK_ATOM(menuitem, "menuitem")
|
||||||
GK_ATOM(menulist, "menulist")
|
GK_ATOM(menulist, "menulist")
|
||||||
GK_ATOM(menupopup, "menupopup")
|
GK_ATOM(menupopup, "menupopup")
|
||||||
|
@ -1781,17 +1781,6 @@ nsMenuPopupFrame::AttributeChanged(PRInt32 aNameSpaceID,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// accessibility needs this to ensure the frames get constructed when the
|
|
||||||
// menugenerated attribute is set, see bug 279703 comment 42 for discussion
|
|
||||||
if (aAttribute == nsGkAtoms::menugenerated &&
|
|
||||||
mFrames.IsEmpty() && !mGeneratedChildren) {
|
|
||||||
EnsureWidget();
|
|
||||||
|
|
||||||
// indicate that the children have been generated and then generate them
|
|
||||||
mGeneratedChildren = PR_TRUE;
|
|
||||||
PresContext()->PresShell()->FrameConstructor()->GenerateChildFrames(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
return rv;
|
return rv;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user