From 2d420c33981231a21d375c0aa8907e0c4c7c8932 Mon Sep 17 00:00:00 2001 From: Steven Lambert Date: Wed, 11 Mar 2020 16:31:41 -0600 Subject: [PATCH] fix(th-has-data-cells): fail when only cell points to different header --- lib/checks/tables/th-has-data-cells.js | 18 ++++++++++++++---- test/checks/tables/th-has-data-cells.js | 20 ++++++++++++++++++++ 2 files changed, 34 insertions(+), 4 deletions(-) diff --git a/lib/checks/tables/th-has-data-cells.js b/lib/checks/tables/th-has-data-cells.js index 9b46be722f..1c8104c1d1 100644 --- a/lib/checks/tables/th-has-data-cells.js +++ b/lib/checks/tables/th-has-data-cells.js @@ -40,19 +40,29 @@ headers.forEach(header => { const pos = tableUtils.getCellPosition(header, tableGrid); - // ensure column header has at least 1 non-header cell + // ensure column header has at least 1 non-header cell and that the cell is + // not pointing to a different header let hasCell = false; if (tableUtils.isColumnHeader(header)) { hasCell = tableUtils .traverse('down', pos, tableGrid) - .find(cell => !tableUtils.isColumnHeader(cell)); + .find( + cell => + !tableUtils.isColumnHeader(cell) && + tableUtils.getHeaders(cell, tableGrid).includes(header) + ); } - // ensure row header has at least 1 non-header cell + // ensure row header has at least 1 non-header cell and that the cell is not + // pointing to a different header if (!hasCell && tableUtils.isRowHeader(header)) { hasCell = tableUtils .traverse('right', pos, tableGrid) - .find(cell => !tableUtils.isRowHeader(cell)); + .find( + cell => + !tableUtils.isRowHeader(cell) && + tableUtils.getHeaders(cell, tableGrid).includes(header) + ); } // report the node as having failed diff --git a/test/checks/tables/th-has-data-cells.js b/test/checks/tables/th-has-data-cells.js index 850705fed7..847c9ab1e8 100644 --- a/test/checks/tables/th-has-data-cells.js +++ b/test/checks/tables/th-has-data-cells.js @@ -139,6 +139,26 @@ describe('th-has-data-cells', function() { ); }); + it('should return undefined if table cell points to a different header', function() { + fixture.innerHTML = + '' + + '' + + '' + + '' + + '' + + '' + + '' + + '' + + '' + + '
Column 1Column 2
'; + + axe.testUtils.flatTreeSetup(fixture); + var node = fixture.querySelector('table'); + assert.isUndefined( + checks['th-has-data-cells'].evaluate.call(checkContext, node) + ); + }); + (shadowSupport ? it : xit)('recognizes shadow tree content', function() { fixture.innerHTML = '
data
'; var shadow = fixture