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

Unexpected behavior of getNodeText #867

Open
jugglinmike opened this issue Dec 30, 2020 · 3 comments
Open

Unexpected behavior of getNodeText #867

jugglinmike opened this issue Dec 30, 2020 · 3 comments

Comments

@jugglinmike
Copy link

  • @testing-library/dom version: 7.28.1
  • Testing Framework and version: Jest 26.6.3
  • DOM Environment: jsdom 16.4.0

Relevant code or config:

const div = document.createElement('div');
div.innerHTML = 'Hello, <span>world</span>!';
expect(getNodeText(div)).toBe('Hello, world!');

What you did:

See above

What happened:

Expected: "Hello, world!"
Received: "Hello, !"

Problem description:

The docs for the getNodeText helper function state (emphasis added):

Returns the complete text content of an HTML element, removing any extra whitespace. The intention is to treat text in nodes exactly as how it is perceived by users in a browser, where any extra whitespace within words in the html code is not meaningful when the text is rendered.

That intention is in-line with the library's overall design goals, but it doesn't seem to match the current implementation.

Based on the description, I expected the function to return all text content of the node and its descendants (a la innerText). Given the following markup:

<div>Hello, <span>world</span>!</div>

A user would likely perceive the text "Hello, world!"

However, the current implementation only considers text nodes which are children of the input node. For the example markup, it returns "Hello, !"

Suggested solution:

As issues like gh-750 demonstrate, it's difficult to confidently say what a user will perceive when presented with text spread across many elements. It might be that this is too nuanced of a concept to expose as a general-purpose API, but I doubt it. For instance, we could observe screen reader semantics--that heuristic is probably imperfect, too, but its real-world usage makes the imperfection meaningful in a way that the current limitations of getNodeText is not.

In any event, thanks for the excellent library!

@RanzQ
Copy link

RanzQ commented Mar 3, 2021

Would be also useful for debugging large elements if we could have a print of the text only. Currently I'm relying on jquery:

$('[data-testid="my-component"]').text()

@jugglinmike Check if the name option in queries is any helpful. It uses the computeAccessibleName from dom-accessibility-api.

Unfortunately it doesn't seem to be perfect either and it cannot be used for all elements:

const button = document.createElement('button');
button.innerHTML = 'Hello, <span>world</span>!';
expect(computeAccessibleName(button)).toBe('Hello, world!');
Expected: "Hello, world!"
Received: "Hello, world !"

@hovsater
Copy link

I just stumbled upon this issue myself. I created the following sandbox to show case the issue. The test fail, because the text content returned is an empty string ("") instead of the expected text, "Click me!".

It looks like this is because we only look at nodes having a node type of 3, which buttons don't have.

@anotheri
Copy link

The same issue is here:

The code looks like:

  const text = getNodeText(el);
  const dom = prettyDOM(el);
  console.log('TEST LOG text', text);
  console.log('TEST LOG dom', dom);

The output:

  console.log
    TEST LOG text


  console.log
    TEST LOG dom
    <td>
      <span>
        0
        <br />
        <b>
          100%
        </b>
      </span>
    </td>

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants