We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
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
https://codesandbox.io/p/devbox/github/joshferrell/user-event-radio-demo/tree/main/
Create a series of radio inputs
<label><input type="radio" name="group" value="a" />A</label> <label><input type="radio" name="group" value="d" />D</label> <label><input type="radio" name="group" value="e" />E</label>
Create a test that confirms radio behavior using the userEvent keyboard function
describe('Radio implementation', () => { test.each([ { name: "per [ArrowDown]", focus: 'A', key: "[ArrowDown]", expectedTarget: 'D', }, { name: "per [ArrowLeft]", focus: 'D', key: "[ArrowLeft]", expectedTarget: 'A', }, { name: "per [ArrowRight]", focus: 'A', key: "[ArrowRight]", expectedTarget: 'D', }, { name: "per [ArrowUp]", focus: 'D', key: "[ArrowUp]", expectedTarget: 'A', }, { name: "forward around the corner", focus: 'E', key: "[ArrowRight]", expectedTarget: 'A', }, { name: "backward around the corner", focus: 'A', key: "[ArrowUp]", expectedTarget: 'E', }, ])('$name', async ({ focus, key, expectedTarget }) => { const user = userEvent.setup() render(<App />) screen.getByLabelText(focus).focus() await user.keyboard(key) expect(screen.getByLabelText(expectedTarget)).toHaveFocus() }) })
If A is selected and ArrowRight is pressed, D should be selected If E is selected and ArrowRight is pressed, A should be selected
If A is selected and ArrowDown is pressed, D should be selected If E is selected and ArrowDown is pressed, A should be selected
If D is selected and ArrowLeft is pressed, A should be selected If A is selected and ArrowLeft is pressed, E should be selected
If D is selected and ArrowUp is pressed, A should be selected If A is selected and ArrowUp is pressed, E should be selected
If A is selected and ArrowRight is pressed, E is selected If E is selected and ArrowRight is pressed, D is selected
If A is selected and ArrowDown is pressed, D is selected If E is selected and ArrowDown is pressed, A is selected
If D is selected and ArrowLeft is pressed, E is selected If A is selected and ArrowLeft is pressed, D is selected
If D is selected and ArrowUp is pressed, A is selected If A is selected and ArrowUp is pressed, E is selected
14.5.2
Testing Library framework: @testing-library/react@14.2.1 and @testing-library/user-event:14.5.2
@testing-library/react@14.2.1
@testing-library/user-event:14.5.2
JS framework: react@18.2.0
react@18.2.0
Test environment: vitest@1.3.1 Also ran in the user-event test suite and had the same issue
vitest@1.3.1
DOM implementation: jsdom@24.0.0
jsdom@24.0.0
There are two issues with the current implementation of the keyboard event and handling radios.
The text was updated successfully, but these errors were encountered:
No branches or pull requests
Reproduction example
https://codesandbox.io/p/devbox/github/joshferrell/user-event-radio-demo/tree/main/
Prerequisites
Create a series of radio inputs
Create a test that confirms radio behavior using the userEvent keyboard function
Expected behavior
Behavior
Arrow Right
If A is selected and ArrowRight is pressed, D should be selected
If E is selected and ArrowRight is pressed, A should be selected
Arrow Down
If A is selected and ArrowDown is pressed, D should be selected
If E is selected and ArrowDown is pressed, A should be selected
Arrow Left
If D is selected and ArrowLeft is pressed, A should be selected
If A is selected and ArrowLeft is pressed, E should be selected
Arrow Up
If D is selected and ArrowUp is pressed, A should be selected
If A is selected and ArrowUp is pressed, E should be selected
Actual behavior
Behavior
Arrow Right
If A is selected and ArrowRight is pressed, E is selected
If E is selected and ArrowRight is pressed, D is selected
Arrow Down
If A is selected and ArrowDown is pressed, D is selected
If E is selected and ArrowDown is pressed, A is selected
Arrow Left
If D is selected and ArrowLeft is pressed, E is selected
If A is selected and ArrowLeft is pressed, D is selected
Arrow Up
If D is selected and ArrowUp is pressed, A is selected
If A is selected and ArrowUp is pressed, E is selected
User-event version
14.5.2
Environment
Testing Library framework:
@testing-library/react@14.2.1
and@testing-library/user-event:14.5.2
JS framework:
react@18.2.0
Test environment:
vitest@1.3.1
Also ran in the user-event test suite and had the same issue
DOM implementation:
jsdom@24.0.0
Additional context
There are two issues with the current implementation of the keyboard event and handling radios.
The text was updated successfully, but these errors were encountered: