~ 2 hours
Here are links to lessons that should be completed before this lesson:
Learn a commonly used testing tool.
Jest is a library for testing JavaScript code. It's an open source project maintained by Facebook, and it's especially well suited for React code testing, although not limited to that: it can test any JavaScript code. from flaviocopes.com
It is built to give clear terminal output about why your test failed, and will even tell you what parts of your code still need to be tested (aka it gives you test coverage data). You can easily write snapshot tests that will alert you to how your new code has caused your web page to change, preventing unintended results as you work.
It works with projects using: Babel, TypeScript, Node, React, Angular, Vue and more. (from https://jestjs.io/)
Which companies use Jest testing?
- Spotify
- AirBnb
Participants will be able to:
- Create a testing structure with Jest
- Create assertion functions
- Generate, display and watch tests
- create test files in your project
- run Jest commands in the terminal
- write test assertions using Jest
Note: How to use these links is described in the Lesson section.
- Jest Official Site: https://jestjs.io/
- Rithm School Jest tutorial: https://www.rithmschool.com/courses/intermediate-react/testing-with-jest
The nice thing about using Jest with React is that it is already included in projects built with create-react-app
. You should just be able to run npm test
in a create-react-app
project folder and it should run Jest. If your project was started another way besides CRA, you can still install jest with npm install --save-dev jest
or yarn add --dev jest
.
-
Spend 5 minutes looking at the jest landing page: https://jestjs.io/
-
Spend ~ 30 minutes following this Rithm School tutorial for Jest. No need to leave the page for the tutorial, but feel free to click around.
-
Spend ~ 30 minutes following Jest Tutorial for Beginners: Getting Started With JavaScript Testing. Note that you can skip these sections for now:
- "Setting up the Project" - you can just add code to your existing project from step 2, so no need to do this part. - "How to test React with Jest" - we'll come to that later. - "Bonus: ES modules with Jest" -
Spend ~ 1 hour following this Jest Tutorial: https://flaviocopes.com/jest/. It reviews some of the things you just covered, but moves on to more complex use cases. Try to run the tests described yourself locally, even if it may not make sense yet.
- File structure: Different testing libraries scan your project for different folder and file names to find your tests.
- For Jest, you'll need a folder named
__tests__
and files that use the pattern inbutton.test.js
orevents.test.ts
. ie:src/App.js, src/__tests__/App.test.js
- If you use a different pattern, jest may not be able to find your file to run it.
- Another default option is to keep a test next to the file it is testing instead of a
__tests__
folder - this will keep it easy to see and your import statement short. ie:src/App.js, src/App.test.js
- You can change this in your project, but it takes some work, and there's no need to get into that now. (Jest docs)
- For Jest, you'll need a folder named
- Don't make your tests hard to find! In general, try to name your test files after the file that they're testing. When testing
listItem.js
, if you name your test filelistItem.test.js
, it's easy to see what it's supposed to be testing when you or a coworker come back later. - Remember: you can get "false positives" and "false negatives" in tests. That's why it's good to follow a Red-Green-Refactor pattern, and make sure that your tests fail before implementing the code to make them pass.
- A test with no expectations in it will pass. Don't forget to add at least one
expect
to everyit
function, or you could end up with this false positive. - Pay attention to when you are writing tests for Asynchronous code. The testing engine might complete before asynchronous code has completed running, giving you unreliable tests. The biggest clue is usually that a test passes sometimes but not others even though you haven't made any changes.
Make yourself a Jest cheatsheet with at least the following:
- How to run Jest tests in the command line
- How to run test coverage with jest in the command line, and what the output means.
- Provide a simple example of a test assertion.