Skip to content

Commit

Permalink
fix(accText): ignore text in embedded content elements (#3022)
Browse files Browse the repository at this point in the history
* fix(accText): ignore text in embedded content elements

Closes  #3017

* Update lib/standards/html-elms.js

* Update lib/standards/html-elms.js

Co-authored-by: Steven Lambert <2433219+straker@users.noreply.github.com>

Co-authored-by: Steven Lambert <2433219+straker@users.noreply.github.com>
  • Loading branch information
WilcoFiers and straker committed Jun 22, 2021
1 parent 2387225 commit 8fb4635
Show file tree
Hide file tree
Showing 5 changed files with 26 additions and 7 deletions.
6 changes: 5 additions & 1 deletion lib/commons/text/subtree-text.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import accessibleTextVirtual from './accessible-text-virtual';
import namedFromContents from '../aria/named-from-contents';
import getOwnedVirtual from '../aria/get-owned-virtual';
import getElementsByContentType from '../standards/get-elements-by-content-type';
import getElementSpec from '../standards/get-element-spec'

/**
* Get the accessible text for an element that can get its name from content
Expand All @@ -15,9 +16,11 @@ function subtreeText(virtualNode, context = {}) {
const { alreadyProcessed } = accessibleTextVirtual;
context.startNode = context.startNode || virtualNode;
const { strict, inControlContext, inLabelledByContext } = context;
const { contentTypes } = getElementSpec(virtualNode);
if (
alreadyProcessed(virtualNode, context) ||
virtualNode.props.nodeType !== 1
virtualNode.props.nodeType !== 1 ||
contentTypes?.includes('embedded') // canvas, video, etc
) {
return '';
}
Expand All @@ -40,6 +43,7 @@ function subtreeText(virtualNode, context = {}) {
const subtreeDescendant = !inControlContext && !inLabelledByContext;
context = { subtreeDescendant, ...context };
}

return getOwnedVirtual(virtualNode).reduce((contentText, child) => {
return appendAccessibleText(contentText, child, context);
}, '');
Expand Down
3 changes: 2 additions & 1 deletion lib/standards/html-elms.js
Original file line number Diff line number Diff line change
Expand Up @@ -671,7 +671,8 @@ const htmlElms = {
noAriaAttrs: true
},
picture: {
contentTypes: ['embedded', 'phrasing', 'flow'],
// Note: spec change (do not count as embedded), because browsers do not hide text inside the picture element
contentTypes: ['phrasing', 'flow'],
allowedRoles: false,
noAriaAttrs: true
},
Expand Down
8 changes: 4 additions & 4 deletions test/checks/shared/has-visible-text.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ describe('has-visible-text', function() {
});

it('should return false if there is no visible text', function() {
var params = checkSetup('<object id="target"></object>');
var params = checkSetup('<p id="target"></p>');
assert.isFalse(
axe.testUtils
.getCheckEvaluate('has-visible-text')
Expand All @@ -23,7 +23,7 @@ describe('has-visible-text', function() {

it('should return false if there is text, but its hidden', function() {
var params = checkSetup(
'<object id="target"><span style="display:none">hello!</span></object>'
'<p id="target"><span style="display:none">hello!</span></p>'
);
assert.isFalse(
axe.testUtils
Expand All @@ -33,7 +33,7 @@ describe('has-visible-text', function() {
});

it('should return true if there is visible text', function() {
var params = checkSetup('<object id="target">hello!</object>');
var params = checkSetup('<p id="target">hello!</p>');
assert.isTrue(
axe.testUtils
.getCheckEvaluate('has-visible-text')
Expand Down Expand Up @@ -75,7 +75,7 @@ describe('has-visible-text', function() {

it('should return true if there is visible text', function() {
var node = new axe.SerialVirtualNode({
nodeName: 'object'
nodeName: 'p'
});
var child = new axe.SerialVirtualNode({
nodeName: '#text',
Expand Down
1 change: 0 additions & 1 deletion test/commons/standards/get-elements-by-content-type.js
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,6 @@ describe('standards.getElementsByContentType', function() {
'img',
'math',
'object',
'picture',
'svg',
'video'
]);
Expand Down
15 changes: 15 additions & 0 deletions test/commons/text/subtree-text.js
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,21 @@ describe('text.subtreeText', function() {
assert.equal(subtreeText(fixture), 'foobarbazfizzbuzz');
});

it('returns `` for embedded content', function() {
fixtureSetup(
'<video>foo</video>' +
'<audio>foo</audio>' +
'<canvas>foo</canvas>' +
'<iframe>foo</iframe>' +
'<svg>foo</svg>'
);
var children = axe._tree[0].children;
assert.lengthOf(children, 5);
children.forEach(function (embeddedContent) {
assert.equal(subtreeText(embeddedContent), '');
});
});

describe('context.processed', function() {
beforeEach(function() {
fixtureSetup('<h1>foo</h1>');
Expand Down

0 comments on commit 8fb4635

Please sign in to comment.