Skip to content

Commit

Permalink
fix(label-content-name-mismatch): ignore non widget aria role(s) & …
Browse files Browse the repository at this point in the history
…do not use deprecated `lookupTable.rolesOfType` (#2022)

* fix: ignore non-widget roles for rule label-content-name-mismatch

* update helper fn for getting role type

* update aria-query

* rollback using aria-query

* updates

* update
  • Loading branch information
jeeyyy authored and straker committed Mar 6, 2020
1 parent c03c0e5 commit 89bd84c
Show file tree
Hide file tree
Showing 4 changed files with 14 additions and 14 deletions.
14 changes: 4 additions & 10 deletions lib/commons/aria/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -1995,7 +1995,7 @@ lookupTable.role = {
allowedElements: ['ol', 'ul']
},
tooltip: {
type: 'widget',
type: 'structure',
attributes: {
allowed: ['aria-expanded', 'aria-errormessage']
},
Expand Down Expand Up @@ -2387,15 +2387,9 @@ lookupTable.evaluateRoleForElement = {
};

/**
* Reference -> https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Techniques#Widget_roles
* The current lookupTable.role['widget'] widget, yeilds
* ->
* [
* "alert", "alertdialog", "button", "checkbox", "dialog", "gridcell", "link", "log", "marquee", "menuitem", "menuitemcheckbox",
* "menuitemradio", "option", "progressbar", "radio", "scrollbar", "searchbox", "slider", "spinbutton", "status", "switch", "tab", "tabpanel",
* "textbox", "timer", "tooltip", "treeitem"
* ]
* There are some differences against specs, hence the below listing was made
* Note:
* Usage of `rolesOfType` is deprecated within the source code.
* Leaving this here for now, to keep support for custom rules.
*/
lookupTable.rolesOfType = {
widget: [
Expand Down
5 changes: 4 additions & 1 deletion lib/rules/label-content-name-mismatch-matches.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,10 @@ if (!role) {
return false;
}

const isWidgetType = aria.lookupTable.rolesOfType.widget.includes(role);
const widgetRoles = Object.keys(aria.lookupTable.role).filter(
key => aria.lookupTable.role[key].type === `widget`
);
const isWidgetType = widgetRoles.includes(role);
if (!isWidgetType) {
return false;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
<button id="pass7" name="link" aria-label="Next Page in the list">
Next Page
</button>

<!-- Fail -->
<div id="fail1" role="link" aria-label="OK">Next</div>
<button id="fail2" name="link" aria-label="the full">The full label</button>
Expand All @@ -38,4 +39,6 @@
<!-- inapplicable -->
<a id="inapplicable1" aria-label="OK">Next</a>
<input id="inapplicable2" type="email" aria-label="E-mail" value="Contact" />
<div id="inapplicable3" role="tooltip" aria-label="OK"></div>
<div id="inapplicable3" role="tooltip" aria-label="OK">Ok</div>
<div id="inapplicable4" role="feed" aria-label="RSS Feed">RSS Feed</div>
<div id="inapplicable5" role="marquee" aria-label="Foo">Foo Restaurant</div>
4 changes: 2 additions & 2 deletions test/rule-matches/label-content-name-mismatch-matches.js
Original file line number Diff line number Diff line change
Expand Up @@ -107,12 +107,12 @@ describe('label-content-name-mismatch-matches tests', function() {
assert.isFalse(actual);
});

it('returns true for widget role that does support name from content', function() {
it('returns false for non-widget role that does support name from content', function() {
var vNode = queryFixture(
'<div id="target" role="tooltip" aria-label="OK">Next</div>'
);
var actual = rule.matches(vNode.actualNode, vNode);
assert.isTrue(actual);
assert.isFalse(actual);
});

it('returns false for empty text content', function() {
Expand Down

0 comments on commit 89bd84c

Please sign in to comment.