From dbbc5442a07b795578f42e282d735e38adfc31dd Mon Sep 17 00:00:00 2001 From: Dylan Barrell Date: Fri, 30 Jun 2017 11:00:27 -0400 Subject: [PATCH] fix: help-same-as-label for shadow DOM --- build/templates.js | 4 ++-- lib/checks/.jshintrc | 1 + lib/checks/label/help-same-as-label.js | 2 +- lib/commons/text/accessible-text.js | 1 + test/checks/label/help-same-as-label.js | 14 +++++++++----- 5 files changed, 14 insertions(+), 8 deletions(-) diff --git a/build/templates.js b/build/templates.js index 4a431b36da..dffc44ada6 100644 --- a/build/templates.js +++ b/build/templates.js @@ -1,8 +1,8 @@ module.exports = { - evaluate: 'function (node, options) {\n<%=source%>\n}', + evaluate: 'function (node, options, virtualNode) {\n<%=source%>\n}', after: 'function (results, options) {\n<%=source%>\n}', gather: 'function (context) {\n<%=source%>\n}', - matches: 'function (node) {\n<%=source%>\n}', + matches: 'function (node, virtualNode) {\n<%=source%>\n}', source: '(function () {\n<%=source%>\n}())', commons: '<%=source%>' }; diff --git a/lib/checks/.jshintrc b/lib/checks/.jshintrc index 0b147d2658..6df1bda954 100644 --- a/lib/checks/.jshintrc +++ b/lib/checks/.jshintrc @@ -3,6 +3,7 @@ "results": true, "node": true, "options": true, + "virtualNode": true, "axe": true, "document": true, "window": true diff --git a/lib/checks/label/help-same-as-label.js b/lib/checks/label/help-same-as-label.js index 4933e977b6..c35b4b9cc4 100644 --- a/lib/checks/label/help-same-as-label.js +++ b/lib/checks/label/help-same-as-label.js @@ -1,5 +1,5 @@ -var labelText = axe.commons.text.label(node), +var labelText = axe.commons.text.label(virtualNode), check = node.getAttribute('title'); if (!labelText) { diff --git a/lib/commons/text/accessible-text.js b/lib/commons/text/accessible-text.js index 7723d239e8..6c6eb3dcf9 100644 --- a/lib/commons/text/accessible-text.js +++ b/lib/commons/text/accessible-text.js @@ -137,6 +137,7 @@ function nonEmptyText(t) { * @return {string} */ text.accessibleText = function(element, inLabelledByContext) { + //todo: implement shadowDOM var accessibleNameComputation; var encounteredNodes = []; diff --git a/test/checks/label/help-same-as-label.js b/test/checks/label/help-same-as-label.js index 19d290ee05..4e45cf736f 100644 --- a/test/checks/label/help-same-as-label.js +++ b/test/checks/label/help-same-as-label.js @@ -5,6 +5,7 @@ describe('help-same-as-label', function () { afterEach(function () { fixture.innerHTML = ''; + axe._tree = undefined; }); it('should return true if an element has a label and a title with the same text', function () { @@ -14,8 +15,8 @@ describe('help-same-as-label', function () { node.setAttribute('aria-label', 'Duplicate'); fixture.appendChild(node); - - assert.isTrue(checks['help-same-as-label'].evaluate(node)); + var tree = axe._tree = axe.utils.getFlattenedTree(fixture); + assert.isTrue(checks['help-same-as-label'].evaluate(node, undefined, axe.utils.getNodeFromTree(tree[0], node))); }); it('should return true if an element has a label and aria-describedby with the same text', function () { @@ -30,7 +31,8 @@ describe('help-same-as-label', function () { fixture.appendChild(node); fixture.appendChild(dby); - assert.isTrue(checks['help-same-as-label'].evaluate(node)); + var tree = axe._tree = axe.utils.getFlattenedTree(fixture); + assert.isTrue(checks['help-same-as-label'].evaluate(node, undefined, axe.utils.getNodeFromTree(tree[0], node))); }); @@ -41,7 +43,8 @@ describe('help-same-as-label', function () { fixture.appendChild(node); - assert.isFalse(checks['help-same-as-label'].evaluate(node)); + var tree = axe._tree = axe.utils.getFlattenedTree(fixture); + assert.isFalse(checks['help-same-as-label'].evaluate(node, undefined, axe.utils.getNodeFromTree(tree[0], node))); }); @@ -56,7 +59,8 @@ describe('help-same-as-label', function () { fixture.appendChild(node); fixture.appendChild(dby); - assert.isFalse(checks['help-same-as-label'].evaluate(node)); + var tree = axe._tree = axe.utils.getFlattenedTree(fixture); + assert.isFalse(checks['help-same-as-label'].evaluate(node, undefined, axe.utils.getNodeFromTree(tree[0], node))); }); }); \ No newline at end of file