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

Update Selector Playground to prioritise suggestions from Testing Library for accessible queries #29779

Closed
ahayes91 opened this issue Jul 1, 2024 · 3 comments
Labels
stale no activity on this issue for a long period topic: selector playground 🚸 type: user experience Improvements needed for UX

Comments

@ahayes91
Copy link

ahayes91 commented Jul 1, 2024

What would you like?

Today I learned (in an interview with a potential QE candidate) about the Selector Playground feature in the Cypress GUI to help you find selectors, and that its suggestions are ordered in a certain priority. While the suggestions align with the concept of writing selectors that are resilient to change, they don't reflect the guiding principles of Testing Library for accessible, user-based queries. There is a short blurb in the Cypress Best Practices docs about the use of Testing Library for locators as a recommendation.

It would be awesome to go one step further and make the Selector Playground recommend Testing Library locators according to their best practice priority.

So, for a button like this:

<button
  id="main"
  class="btn btn-large"
  name="submission"
  role="button"
  data-cy="submit"
>
  Submit
</button>

I would love for the first suggestion to be cy.findByRole('button', {name: 'Submit'}) instead of cy.get('[data-cy="submit"]').

(One reason you might not want that would be in an application testing multiple languages - but then I'd argue your test should still be testing that your buttons are getting the appropriate labels for that language 😏 )

Why is this needed?

  • It will help engineers using Cypress to get familiar with the importance of user-based, accessible queries.
  • More tests using accessible queries means less bugs and more thoughtfulness around accessibility in the wild web.
  • Less a11y bugs means better user experience for everyone!

Other

No response

@jennifer-shehane
Copy link
Member

Thanks for the feedback. You can edit the priority as a workaround today: https://docs.cypress.io/api/cypress-api/selector-playground-api#Arguments

@cypress-app-bot
Copy link
Collaborator

This issue has not had any activity in 180 days. Cypress evolves quickly and the reported behavior should be tested on the latest version of Cypress to verify the behavior is still occurring. It will be closed in 14 days if no updates are provided.

@cypress-app-bot cypress-app-bot added the stale no activity on this issue for a long period label Dec 29, 2024
@cypress-app-bot
Copy link
Collaborator

This issue has been closed due to inactivity.

@cypress-app-bot cypress-app-bot closed this as not planned Won't fix, can't repro, duplicate, stale Jan 12, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
stale no activity on this issue for a long period topic: selector playground 🚸 type: user experience Improvements needed for UX
Projects
None yet
Development

No branches or pull requests

3 participants