Skip to content
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

getByRole fails if filtering by accessible name with   in it #904

Closed
jegtnes opened this issue Feb 26, 2021 · 5 comments
Closed

getByRole fails if filtering by accessible name with   in it #904

jegtnes opened this issue Feb 26, 2021 · 5 comments
Labels
enhancement New feature or request

Comments

@jegtnes
Copy link

jegtnes commented Feb 26, 2021

  • @testing-library/dom version: 7.28.1 (via react-testing-library 11.2.5)
  • Testing Framework and version: Jest 26.6.3
  • DOM Environment: JSDom 16.2.1

Relevant code or config:

DOM:

<label for="testy">Fascinating&nbsp;input</label>
<input id="testy" name="ice-cream-flavour" />

Test code:

expect(
  screen.getByRole("textbox", { name: "Fascinating input" })
).toBeInTheDocument();

What you did:

Attempted to find an element by role with a non-breaking space in the accessible name, by searching for the accessible name without having to encode a non-breaking space in JavaScript where the space goes (\xa0).

What happened:

Fails on getByRole

If searching for the accessible name with a regular space in getByRole, the test will fail.

getByRole("textbox", { name: "Fascinating input" })

Succeds on getByLabelText

If searching for the name with a regular space in getByLabelText, the test will succeed.

getByLabelText("Fascinating input"))

Succeeds on getByRole with \xa0 instead of a regular space

If searching for the accessible name with a JS representation of &nbsp, \xa0 in getByRole, the test will succeed.

getByRole("textbox", { name: "Fascinating\xa0input" })

Fails on getByLabelText with \xa0 instead of a regular space

If searching for the name with a JS representation of &nbsp, \xa0, in getByLabelText the test will fail.

getByLabelText("Fascinating\xa0input")

Reproduction:

Codesandbox reproduction

Problem description:

This seems incongrugous with testing-library's philosophy of "testing what the user sees", and is additionally inconsistent with other methods. If there's a reason we must specifically encode a breaking space to test for an element with a breaking space in the accessible name, it might be a good idea to be clearer about this in the error messaging. I was converting an existing code base from Enzyme to react-testing-library, and seeing an error like this understandably confused me a bit:

Fails on getByRole. TestingLibraryElementError: Unable to find an accessible element with the role "textbox" and name "Fascinating input". Here are the accessible roles: textbox: Name "Fascinating input": <input />

Suggested solution:

  • Make the text matching/parsing consistent between different methods
  • If the above isn't feasible, make this error clearer in the error output by highlighting the breaking space, or lack thereof

As an aside

Since the issue template makes me seem extremely clinical, I just wanted to highlight I'm not an ungrateful jerk (I hope) and would like to thank all the contributors for a wonderful piece of work! The philosophy behind testing-library makes a lot of sense and I'm really enjoying working with it. ✨

@eps1lon eps1lon added the enhancement New feature or request label Feb 27, 2021
@katesroad
Copy link

I'm using version "@testing-library/react": "^11.2.5",. My code works using in this way.

 <label
                class="sc-gsTCUz kHIuWv"
                for="senderAddress.postcode"
              >
                post code
              </label>
              <input
                class="sc-dlfnbm sc-hKgILt fxqgV code"
                id="senderAddress.postcode"
                name="senderAddress.postcode"
                value="sender postcode"
                variant=""
              />
              <small
                class="sc-eCssSg dEHZqf"
              />
            </div>

and here is my testing code

	expect(screen.getByRole("textbox", { name: /post code/i })).toHaveValue(
		senderAddress.postcode
	);

@savcni01
Copy link
Contributor

savcni01 commented May 5, 2021

I plan to work on this issue today.

It looks like the issue is related (if not similar) to #890

savcni01 added a commit to savcni01/dom-testing-library that referenced this issue May 5, 2021
…and `ByRole` queries

  - first step to fix testing-library#904 - not similar behaviour of `ByLabelText` and `ByRole, {name: ''}` with nbsp at DOM
@eps1lon
Copy link
Member

eps1lon commented Aug 25, 2021

Closing since it's unclear if we really want this. The normalizer would also collapse newlines and it should be obvious in tests if you really want newlines in the name.

Note that you can always do getByRole('textbox', { name: 'Fascinating&nbsp;input' }) or getByRole('textbox', { name: name => name.replace(/\s+/g, ' ') === Fascinating input }) if you are sure that the whitespace should be collapsed. And you can always create a custom wrapper that implements this behavior by default.

ByRole is not intended to work just like ByLabelText. Otherwise we wouldn't need two queries. ByRole is a strict, spec compliant query. Following the spec avoids having extensive discussions that we're not equipped to have.

If you have a strong argument for collapsing whitespace then please file an issue against https://github.com/w3c/accname though w3c/accname#95 might already be similar.

There may be an argument for replacing &nbsp; specifically with just ' ' since I believe word-breaking is just a visual thing. But again, let's have this discussion in the spec.

@cookiecrook
Copy link

cookiecrook commented Apr 20, 2024

For future reference, the ARIA spec and soon the WPT tests align on ASCII white space which does not include non-breaking white space. So it was correct to close this. NBSP should never be converted or collapsed to “ “ in the label context.

@russellEngAsana
Copy link

I understand the decision not to update getByRole but just curious if there is an easy way to update the error message in this case to inform the user. I just spent an embarrassingly long time trying to figure out why my test wouldn't pass when everything suggested my query was correct

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
6 participants