diff --git a/lib/checks/aria/required-children.js b/lib/checks/aria/required-children.js index afbf76f822..8183bc1d4f 100644 --- a/lib/checks/aria/required-children.js +++ b/lib/checks/aria/required-children.js @@ -13,7 +13,9 @@ function owns(node, virtualTree, role, ariaOwned) { selector = ['[role="' + role + '"]']; if (implicit) { - selector = selector.concat(implicit); + selector = selector.concat( + implicit.map(implicitSelector => implicitSelector + ':not([role])') + ); } selector = selector.join(','); @@ -62,13 +64,15 @@ function missingRequiredChildren(node, childRoles, all, role) { // combobox exceptions if (role === 'combobox') { - // remove 'textbox' from missing roles if combobox is a native text-type input + // remove 'textbox' from missing roles if combobox is a native text-type input or owns a 'searchbox' var textboxIndex = missing.indexOf('textbox'); var textTypeInputs = ['text', 'search', 'email', 'url', 'tel']; if ( - textboxIndex >= 0 && - node.nodeName.toUpperCase() === 'INPUT' && - textTypeInputs.includes(node.type) + (textboxIndex >= 0 && + (node.nodeName.toUpperCase() === 'INPUT' && + textTypeInputs.includes(node.type))) || + (owns(node, virtualNode, 'searchbox') || + ariaOwns(ownedElements, 'searchbox')) ) { missing.splice(textboxIndex, 1); } diff --git a/test/checks/aria/required-children.js b/test/checks/aria/required-children.js index cc6bfe00ad..959d561a4f 100644 --- a/test/checks/aria/required-children.js +++ b/test/checks/aria/required-children.js @@ -287,6 +287,24 @@ describe('aria-required-children', function() { ); }); + it('should pass role comboxbox when child is native "search" input type', function() { + var params = checkSetup( + '
Textbox
Textbox