-
Notifications
You must be signed in to change notification settings - Fork 791
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fix(label-content-name-mismatch): better dismiss and wysiwyg symbolic text characters #4402
fix(label-content-name-mismatch): better dismiss and wysiwyg symbolic text characters #4402
Conversation
… text characters adds exceptions for (dismiss) ×, wysiwyg characters b, aA, abc fix: #4386
test/integration/rules/label-content-name-mismatch/label-content-name-mismatch.html
Show resolved
Hide resolved
Should switch to case insensitive for symbolic text |
As discussed, we'll want to add a test that uses a single CJK character (any of the 3) for the label and a different one for the visible text and show that it returns incomplete, that way we document the behavior (previous to this change CJK would pass/fail for single characters if different). |
…, ignore cap Addresses all feedback on PR #4402 - Simpler symbolic text check, ignoring case, with unit test for both - Added back "x" and "X" in unit test - Removed trim step, uneeded - Reverted set to list, uneeded - removed /i in non-digit regex - test for a CJK character - adjusted integration test labels for single character incompletes, noticed an ordering bug and corrected Refs: #4386
Followed Steven's advice for a simpler non-digit single character check, added a test to show a digit isn't incompleted Refs: #4386
|
requested changes addressed
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the updates, LGTM!
|
||
if ( | ||
isHumanInterpretable(accText) < 1 || | ||
isHumanInterpretable(visibleText) < 1 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I had to think about this for a while, but I think I agree with your changes here. I think this creates 2 (but really 1) behavior changes:
- If
accText
is not interpretable andvisibleText
is empty- Previously
incomplete
, nowpass
- This is irrelevant in practice because
label-content-name-mismatch-matches
filters out cases without visible text
- Previously
- If
accText
is interpretable,visibleText
is not intepretable, andvisibleText
is contained inaccText
- Previously
pass
, nowincomplete
- Example:
<button aria-label="bold">B</button>
- Previously
Previously I think that case would pass (return true
) - with this change, I think it incompletes (returns undefined
). I think it's more consistent with the change (I don't think it makes sense for a visible "x" button to give different results for labels "close" vs "exit").
### [4.9.1](v4.9.0...v4.9.1) (2024-05-06) ### Bug Fixes - Prevent errors when loading axe in a page with prototype.js - **aria-allowed-attr:** allow meter role allowed aria-\* attributes on meter element ([#4435](#4435)) ([7ac6392](7ac6392)) - **aria-allowed-role:** add gridcell, separator, slider and treeitem to allowed roles of button element ([#4398](#4398)) ([4788bf8](4788bf8)) - **aria-roles:** correct abstract roles (types) for aria-roles([#4421](#4421)) - **aria-valid-attr-value:** aria-controls & aria-haspopup incomplete ([#4418](#4418)) - fix building axe-core translation files with region locales ([#4396](#4396)) ([5c318f3](5c318f3)), closes [#4388](#4388) - **invalidrole:** allow upper and mixed case role names ([#4358](#4358)) ([105016c](105016c)), closes [#2695](#2695) - **isVisibleOnScreen:** account for position: absolute elements inside overflow container ([#4405](#4405)) ([2940f6e](2940f6e)), closes [#4016](#4016) - **label-content-name-mismatch:** better dismiss and wysiwyg symbolic text characters ([#4402](#4402)) - **region:** Decorative images ignored by region rule ([#4412](#4412)) - **target-size:** ignore descendant elements in shadow dom ([#4410](#4410)) ([6091367](6091367)) - **target-size:** pass for element that has nearby elements that are obscured ([#4422](#4422)) ([3a90bb7](3a90bb7)), closes [#4387](#4387) This PR was opened by a robot 🤖 🎉 (And updated by @WilcoFiers )
adds exceptions for (dismiss)
×
, wysiwyg charactersb
,aA
,abc
fix: #4386
This does not handle all potential use cases. Potential shortcomings worth discussing and opening further issues for are as follows:
ABC
example