Not accessible
React told me off!
data:image/s3,"s3://crabby-images/90197/9019709b47ffa37798c77a77cb30e05d63d891a3" alt="Wireframe of a website, with icon and navigation at the top, hero image, then text content"
Why test code?
Reduce errors on complex interactive sites
data:image/s3,"s3://crabby-images/4b316/4b3160c298fb9d2f45b72ff58391d6ccde02d13c" alt="Simplified UI of 4 to-do list states, empty, with an item added, done, and archived"
React
Testing Library
Enforce user centric tests
<Button
label="Add a new fish"
onClick="this.showFishInput"
/>
<Input
aria-label="Fish name"
class="fishInput"
/>
fireEvent.showFishInput()
expect(<Input class="fishInput"/>) to render 🤯
<Button
label="Add a new fish"
onClick="this.showFishInput"
/>
<Input
aria-label="Fish name"
class="fishInput"
/>
userEvent.click(screen.getByText('Add a new fish'));
expect(
screen.getByRole('input', { name: 'Fish name' })
).toBeInTheDocument(); ❤️
data:image/s3,"s3://crabby-images/56676/566762c3cddf24ca790131681573c0ff77b26b90" alt="Simplified UI of 2 identical looking interactive elements, which could be a select box or a dropdown. One element's accessible name is Fish habitat, fresh water. Another element's name is Fish habitat."
data:image/s3,"s3://crabby-images/ef1fd/ef1fda50ab7b6fb4d4199575dc31ea154f526e48" alt="Simplified UI of 2 identical looking interactive elements. The first element, which is a select input, has a visible label called Fish Habitat, showing that Fresh water option was selected. Its accessible name is Fish habitat, Fresh water. Another element is a custom dropdown menu with both visible and accessible name of Fish habitat."
What about React?
Improved docs,
development assistance, & bundling
<img src="fishyImage.png"/>
(image-alt):
Ensures <img> elements have alternate text
or a role of none or presentation
<button tabindex="2">
Add a new fish
</button>
(tabindex):
Ensures tabindex attribute values
are not greater than 0
Create React App
People can
ignore tests?!
Yes... but you can make it harder
Bake it in
TDD, prevent commits & stop deploys
React told me off
...but not all the time
Bots don't know UX
Good HTML & copy...
We need humans for that
Accessibility is a mindset,
not a standalone activity