haikuwebkit/LayoutTests/accessibility/list-detection2.html

222 lines
8.1 KiB
HTML
Raw Permalink Normal View History

<!DOCTYPE HTML>
<html>
<head>
<title>List; presentation heuristics</title>
<meta charset="utf-8">
<style type="text/css">
html, body {
font-size: 100%;
}
h1 {
font-size: 1em;
}
.inline, .inline li {
display: inline;
}
.nomarkers {
list-style: none;
}
.imagemarkers {
list-style-image: url();
}
.imagemarkersbefore li::before {
content: url() " ";
}
.bulletmarkersbefore li::before {
content: "• ";
}
.countermarkersbefore {
counter-reset: number;
list-style-type: none;
}
.countermarkersbefore li::before {
counter-increment: number;
content: counters(number,".") ". ";
}
.backgroundmarkers li {
padding-left: 30px;
background: transparent url() left center no-repeat;
}
.backgroundmarkersbefore li::before {
display: inline-block;
content: " ";
width: 17px;
height: 17px;
background: transparent url() left center no-repeat;
}
</style>
</head>
<body onload="runTest();">
<script src="../resources/js-test-pre.js"></script>
<div id="examples">
<!-- @data-role is the expectation -->
<h1>list because of explicit role, despite style and lack of list markers</h1>
<ul role="list" data-role="list" class="ex inline" data-note=" w/ explicit role and displayed inline">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ul>
<ul role="list" data-role="list" class="ex nomarkers" data-note=" w/ explicit role but no markers">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ul>
<h1>list because of rendered list markers (exposed as AXListMarker)</h1>
<ul data-role="list" class="ex" data-note=" w/ default list markers">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ul>
<ol data-role="list" class="ex" data-note=" w/ default list counters">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ol>
<ul data-role="list" class="ex imagemarkers" data-note=" w/ list-style-image">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ul>
<h1>list because these list markers consist of CSS-generated content on ::before pseudo element. Note: WebKit is not exposing these as AXListMarker; need another bug for that.</h1>
<ul data-role="list" class="ex nomarkers imagemarkersbefore" data-note=" w/ image content on ::before">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ul>
<ul data-role="list" class="ex nomarkers inline imagemarkersbefore" data-note=" w/ image content on inline ::before">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ul>
<ul data-role="list" class="ex nomarkers bulletmarkersbefore" data-note=" w/ bullet content on ::before">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ul>
<ul data-role="list" class="ex nomarkers inline bulletmarkersbefore" data-note=" w/ bullet content on inline ::before">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ul>
<ol data-role="list" class="ex nomarkers countermarkersbefore" data-note=" w/ counter content on ::before">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ol>
<ol data-role="list" class="ex nomarkers inline countermarkersbefore" data-note=" w/ counter content on inline ::before">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ol>
<div role="navigation">
<div>
<ul data-role="list" class="ex nomarkers" style="list-style-type:none" data-note=" list in a navigation role">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ul>
</div>
</div>
<nav>
<div>
<ol data-role="list" class="ex nomarkers" style="list-style-type:none" data-note=" list in a nav element">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ol>
</div>
</nav>
<p>Since many web pages suffer from "list-itis" and some users have noted that they don't want to hear about so many lists, any UL or OL that does not match one of the above heuristics should not be exposed as a list. Chances are that they are just presentational lists using the elements for the sake of a styling hook.</p>
<h1>EXPLICIT FAILURE CASES: These next examples are <strong>NOT</strong> lists because these "list markers" are faked as background images. One is even a background image on a ::before pseudo-element, but that does not count as a listmarker. List markers should only be inferred by the <code>content</code> property or the <code>list-style</code> properties.</h1>
AX: Expose a new AXSubrole for explicit ARIA "group" role https://bugs.webkit.org/show_bug.cgi?id=169810 <rdar://problem/31039693> Reviewed by Chris Fleizach. Source/WebCore: Split GroupRole into generics (GroupRole) and explicit groups (ApplicationGroupRole) so we can expose a subrole on the explicit groups. Account for the change in ARIA Tree and Menu hierachies. Update the computedRoleValue for WebKit Inspector usage, too. Updated existing tests. Test: accessibility/list-detection2.html: Test: accessibility/roles-computedRoleString.html: Test: inspector/dom/getAccessibilityPropertiesForNode.html: Test: inspector/dom/highlightFrame.html: Test: inspector/dom/highlightSelector.html: * accessibility/AccessibilityNodeObject.cpp: (WebCore::AccessibilityNodeObject::helpText): (WebCore::AccessibilityNodeObject::hierarchicalLevel): (WebCore::AccessibilityNodeObject::remapAriaRoleDueToParent): * accessibility/AccessibilityObject.cpp: (WebCore::AccessibilityObject::accessibleNameDerivesFromContent): (WebCore::AccessibilityObject::ariaTreeItemContent): (WebCore::initializeRoleMap): (WebCore::AccessibilityObject::computedRoleString): * accessibility/AccessibilityObject.h: * accessibility/atk/WebKitAccessibleWrapperAtk.cpp: (atkRole): * accessibility/ios/WebAccessibilityObjectWrapperIOS.mm: (-[WebAccessibilityObjectWrapper determineIsAccessibilityElement]): * accessibility/mac/WebAccessibilityObjectWrapperMac.mm: (createAccessibilityRoleMap): (-[WebAccessibilityObjectWrapper subrole]): Source/WebKit/win: Account for Windows platform role mapping. * AccessibleBase.cpp: (MSAARole): LayoutTests: * accessibility/list-detection2-expected.txt: * accessibility/list-detection2.html: * accessibility/roles-computedRoleString.html: * inspector/dom/getAccessibilityPropertiesForNode-expected.txt: * inspector/dom/highlightFrame-expected.txt: * inspector/dom/highlightSelector-expected.txt: * platform/mac/accessibility/roles-computedRoleString-expected.txt: * platform/mac/accessibility/roles-exposed-expected.txt: Canonical link: https://commits.webkit.org/187219@main git-svn-id: https://svn.webkit.org/repository/webkit/trunk@214623 268f45cc-cd09-0410-ab3c-d52691b4dbfc
2017-03-30 21:13:21 +00:00
<ul data-role="" class="ex nomarkers backgroundmarkers" data-note=" w/ background image (NOT A LIST)">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ul>
AX: Expose a new AXSubrole for explicit ARIA "group" role https://bugs.webkit.org/show_bug.cgi?id=169810 <rdar://problem/31039693> Reviewed by Chris Fleizach. Source/WebCore: Split GroupRole into generics (GroupRole) and explicit groups (ApplicationGroupRole) so we can expose a subrole on the explicit groups. Account for the change in ARIA Tree and Menu hierachies. Update the computedRoleValue for WebKit Inspector usage, too. Updated existing tests. Test: accessibility/list-detection2.html: Test: accessibility/roles-computedRoleString.html: Test: inspector/dom/getAccessibilityPropertiesForNode.html: Test: inspector/dom/highlightFrame.html: Test: inspector/dom/highlightSelector.html: * accessibility/AccessibilityNodeObject.cpp: (WebCore::AccessibilityNodeObject::helpText): (WebCore::AccessibilityNodeObject::hierarchicalLevel): (WebCore::AccessibilityNodeObject::remapAriaRoleDueToParent): * accessibility/AccessibilityObject.cpp: (WebCore::AccessibilityObject::accessibleNameDerivesFromContent): (WebCore::AccessibilityObject::ariaTreeItemContent): (WebCore::initializeRoleMap): (WebCore::AccessibilityObject::computedRoleString): * accessibility/AccessibilityObject.h: * accessibility/atk/WebKitAccessibleWrapperAtk.cpp: (atkRole): * accessibility/ios/WebAccessibilityObjectWrapperIOS.mm: (-[WebAccessibilityObjectWrapper determineIsAccessibilityElement]): * accessibility/mac/WebAccessibilityObjectWrapperMac.mm: (createAccessibilityRoleMap): (-[WebAccessibilityObjectWrapper subrole]): Source/WebKit/win: Account for Windows platform role mapping. * AccessibleBase.cpp: (MSAARole): LayoutTests: * accessibility/list-detection2-expected.txt: * accessibility/list-detection2.html: * accessibility/roles-computedRoleString.html: * inspector/dom/getAccessibilityPropertiesForNode-expected.txt: * inspector/dom/highlightFrame-expected.txt: * inspector/dom/highlightSelector-expected.txt: * platform/mac/accessibility/roles-computedRoleString-expected.txt: * platform/mac/accessibility/roles-exposed-expected.txt: Canonical link: https://commits.webkit.org/187219@main git-svn-id: https://svn.webkit.org/repository/webkit/trunk@214623 268f45cc-cd09-0410-ab3c-d52691b4dbfc
2017-03-30 21:13:21 +00:00
<ul data-role="" class="ex nomarkers backgroundmarkersbefore" data-note=" w/ background on ::before (NOT A LIST)">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ul>
<h1>EXPLICIT FAILURE CASES: These next examples are <strong>NOT</strong> there is no explicit role or any style or list markers to indicate this is actually intended as a list.</h1>
AX: Expose a new AXSubrole for explicit ARIA "group" role https://bugs.webkit.org/show_bug.cgi?id=169810 <rdar://problem/31039693> Reviewed by Chris Fleizach. Source/WebCore: Split GroupRole into generics (GroupRole) and explicit groups (ApplicationGroupRole) so we can expose a subrole on the explicit groups. Account for the change in ARIA Tree and Menu hierachies. Update the computedRoleValue for WebKit Inspector usage, too. Updated existing tests. Test: accessibility/list-detection2.html: Test: accessibility/roles-computedRoleString.html: Test: inspector/dom/getAccessibilityPropertiesForNode.html: Test: inspector/dom/highlightFrame.html: Test: inspector/dom/highlightSelector.html: * accessibility/AccessibilityNodeObject.cpp: (WebCore::AccessibilityNodeObject::helpText): (WebCore::AccessibilityNodeObject::hierarchicalLevel): (WebCore::AccessibilityNodeObject::remapAriaRoleDueToParent): * accessibility/AccessibilityObject.cpp: (WebCore::AccessibilityObject::accessibleNameDerivesFromContent): (WebCore::AccessibilityObject::ariaTreeItemContent): (WebCore::initializeRoleMap): (WebCore::AccessibilityObject::computedRoleString): * accessibility/AccessibilityObject.h: * accessibility/atk/WebKitAccessibleWrapperAtk.cpp: (atkRole): * accessibility/ios/WebAccessibilityObjectWrapperIOS.mm: (-[WebAccessibilityObjectWrapper determineIsAccessibilityElement]): * accessibility/mac/WebAccessibilityObjectWrapperMac.mm: (createAccessibilityRoleMap): (-[WebAccessibilityObjectWrapper subrole]): Source/WebKit/win: Account for Windows platform role mapping. * AccessibleBase.cpp: (MSAARole): LayoutTests: * accessibility/list-detection2-expected.txt: * accessibility/list-detection2.html: * accessibility/roles-computedRoleString.html: * inspector/dom/getAccessibilityPropertiesForNode-expected.txt: * inspector/dom/highlightFrame-expected.txt: * inspector/dom/highlightSelector-expected.txt: * platform/mac/accessibility/roles-computedRoleString-expected.txt: * platform/mac/accessibility/roles-exposed-expected.txt: Canonical link: https://commits.webkit.org/187219@main git-svn-id: https://svn.webkit.org/repository/webkit/trunk@214623 268f45cc-cd09-0410-ab3c-d52691b4dbfc
2017-03-30 21:13:21 +00:00
<ul data-role="" class="ex inline" data-note=" w/o explicit role and displayed inline, which defaults to no markers (NOT A LIST)">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ul>
AX: Expose a new AXSubrole for explicit ARIA "group" role https://bugs.webkit.org/show_bug.cgi?id=169810 <rdar://problem/31039693> Reviewed by Chris Fleizach. Source/WebCore: Split GroupRole into generics (GroupRole) and explicit groups (ApplicationGroupRole) so we can expose a subrole on the explicit groups. Account for the change in ARIA Tree and Menu hierachies. Update the computedRoleValue for WebKit Inspector usage, too. Updated existing tests. Test: accessibility/list-detection2.html: Test: accessibility/roles-computedRoleString.html: Test: inspector/dom/getAccessibilityPropertiesForNode.html: Test: inspector/dom/highlightFrame.html: Test: inspector/dom/highlightSelector.html: * accessibility/AccessibilityNodeObject.cpp: (WebCore::AccessibilityNodeObject::helpText): (WebCore::AccessibilityNodeObject::hierarchicalLevel): (WebCore::AccessibilityNodeObject::remapAriaRoleDueToParent): * accessibility/AccessibilityObject.cpp: (WebCore::AccessibilityObject::accessibleNameDerivesFromContent): (WebCore::AccessibilityObject::ariaTreeItemContent): (WebCore::initializeRoleMap): (WebCore::AccessibilityObject::computedRoleString): * accessibility/AccessibilityObject.h: * accessibility/atk/WebKitAccessibleWrapperAtk.cpp: (atkRole): * accessibility/ios/WebAccessibilityObjectWrapperIOS.mm: (-[WebAccessibilityObjectWrapper determineIsAccessibilityElement]): * accessibility/mac/WebAccessibilityObjectWrapperMac.mm: (createAccessibilityRoleMap): (-[WebAccessibilityObjectWrapper subrole]): Source/WebKit/win: Account for Windows platform role mapping. * AccessibleBase.cpp: (MSAARole): LayoutTests: * accessibility/list-detection2-expected.txt: * accessibility/list-detection2.html: * accessibility/roles-computedRoleString.html: * inspector/dom/getAccessibilityPropertiesForNode-expected.txt: * inspector/dom/highlightFrame-expected.txt: * inspector/dom/highlightSelector-expected.txt: * platform/mac/accessibility/roles-computedRoleString-expected.txt: * platform/mac/accessibility/roles-exposed-expected.txt: Canonical link: https://commits.webkit.org/187219@main git-svn-id: https://svn.webkit.org/repository/webkit/trunk@214623 268f45cc-cd09-0410-ab3c-d52691b4dbfc
2017-03-30 21:13:21 +00:00
<ol data-role="" class="ex inline" data-note=" w/o explicit role and displayed inline, which defaults to no markers (NOT A LIST)">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ol>
AX: Expose a new AXSubrole for explicit ARIA "group" role https://bugs.webkit.org/show_bug.cgi?id=169810 <rdar://problem/31039693> Reviewed by Chris Fleizach. Source/WebCore: Split GroupRole into generics (GroupRole) and explicit groups (ApplicationGroupRole) so we can expose a subrole on the explicit groups. Account for the change in ARIA Tree and Menu hierachies. Update the computedRoleValue for WebKit Inspector usage, too. Updated existing tests. Test: accessibility/list-detection2.html: Test: accessibility/roles-computedRoleString.html: Test: inspector/dom/getAccessibilityPropertiesForNode.html: Test: inspector/dom/highlightFrame.html: Test: inspector/dom/highlightSelector.html: * accessibility/AccessibilityNodeObject.cpp: (WebCore::AccessibilityNodeObject::helpText): (WebCore::AccessibilityNodeObject::hierarchicalLevel): (WebCore::AccessibilityNodeObject::remapAriaRoleDueToParent): * accessibility/AccessibilityObject.cpp: (WebCore::AccessibilityObject::accessibleNameDerivesFromContent): (WebCore::AccessibilityObject::ariaTreeItemContent): (WebCore::initializeRoleMap): (WebCore::AccessibilityObject::computedRoleString): * accessibility/AccessibilityObject.h: * accessibility/atk/WebKitAccessibleWrapperAtk.cpp: (atkRole): * accessibility/ios/WebAccessibilityObjectWrapperIOS.mm: (-[WebAccessibilityObjectWrapper determineIsAccessibilityElement]): * accessibility/mac/WebAccessibilityObjectWrapperMac.mm: (createAccessibilityRoleMap): (-[WebAccessibilityObjectWrapper subrole]): Source/WebKit/win: Account for Windows platform role mapping. * AccessibleBase.cpp: (MSAARole): LayoutTests: * accessibility/list-detection2-expected.txt: * accessibility/list-detection2.html: * accessibility/roles-computedRoleString.html: * inspector/dom/getAccessibilityPropertiesForNode-expected.txt: * inspector/dom/highlightFrame-expected.txt: * inspector/dom/highlightSelector-expected.txt: * platform/mac/accessibility/roles-computedRoleString-expected.txt: * platform/mac/accessibility/roles-exposed-expected.txt: Canonical link: https://commits.webkit.org/187219@main git-svn-id: https://svn.webkit.org/repository/webkit/trunk@214623 268f45cc-cd09-0410-ab3c-d52691b4dbfc
2017-03-30 21:13:21 +00:00
<ul data-role="" class="ex nomarkers" data-note=" w/o explicit role and no markers (NOT A LIST)">
<li>foo</li>
<li>bar</li>
<li>baz</li>
</ul>
</div>
<div id="console"></div>
<script>
function runTest() {
if (window.testRunner && window.accessibilityController) {
description("This tests that heurisitics for determining meaningful lists versus presentational lists result in the same computed role, regardless of platform.")
var examples = document.querySelectorAll(".ex");
var el, contentAttrRoleString, axElement, computedAriaRole, output, expectedRole, expectation, result, note;
for (var i = 0, c = examples.length; i < c; i++) {
el = examples[i];
el.id = "ex" + i
axElement = accessibilityController.accessibleElementById(el.id);
if (!axElement)
continue;
computedAriaRole = axElement.computedRoleString;
contentAttrRoleString = el.getAttribute("role");
note = el.getAttribute("data-note")
output = el.tagName.toLowerCase() + (contentAttrRoleString ? ("[role=\""+contentAttrRoleString+"\"]") : "") + (note ? note : "");
output += " -> ";
output += computedAriaRole;
output += ". ";
expectedRole = "";
if (el.hasAttribute("data-role")) {
expectedRole = el.getAttribute("data-role");
}
expectation = expectedRole;
matchedResults = (computedAriaRole == expectedRole)
result = document.getElementById('console');
if (matchedResults) {
result.innerText += "PASS: " + output + "\n";
} else {
result.innerText += "FAIL: " + output + "Expected: " + expectation + ".\n";
}
}
// Once tests are complete, hide all the example markup.
examples = document.querySelectorAll(".ex, #examples");
for (var i = 0, c = examples.length; i < c; i++)
examples[i].style.display = "none";
}
}
</script>
<script src="../resources/js-test-post.js"></script>
</body>
</html>