2016 in Jest
2016 was a big year for JavaScript testing with Jest. In the first six months of the year we rewrote Jest and built a solid foundation to significantly improve performance and the developer experience of testing JavaScript code. We flow-typed the entire codebase, built a ton of integration tests for Jest itself and adopted lerna to turn Jest from a framework into a Painless JavaScript Testing platform.
The newly created react-test-renderer finally enabled testing of react-native components. Through the jest-react-native preset (now merged directly into react-native) Jest now works out of the box for any React project and comes pre-configured in create-react-app and react-native projects. We integrated core pieces of Jest into react-native's packager and the completely new snapshot testing feature has since been used outside of Jest: It was integrated with React Storybook as “storyshots” and is being adopted by other test runners like ava.
The pretty-format project was rewritten with performance in mind to drive Jest's snapshot feature, was recently merged into Jest's monorepo and is also helpful in other test runners. Nowadays Jest is much more about collecting different ideas and solutions to testing than it is about one specific implementation of a test framework.
I'd like to deeply thank all the people that have contributed to Jest this year, both from the open source community and at Facebook: Dmitrii Abramov, Cristian Carlesso, Dan Abramov, Daniel Lo Nigro, Maxim Derbin, Evan Scott, Forbes Lindesay, Keyan Zhang and 60 more people. We'd also like to welcome Michał Pierzchała (@thymikee) as first official external contributor to Jest. He's been doing a great job managing the issues and PRs on the repo. If you'd like to start contributing to Jest, we have a bunch of good first tasks and we are always happy to help on our discord channel.
repl.it with Jest integration
Amjad Massad built a Jest container so you can now try out Jest directly in the browser. You can use it from now on when creating GitHub issues which should help troubleshoot problems more quickly. Amjad and Haya are building repl.it to democratize programming by building powerful yet simple tools and platforms for educators, learners, and developers. They are also hiring talented engineers!
Community Update
We feel incredibly humbled that 100+ companies have adopted Jest in the last six months. Companies like Twitter, Pinterest, Paypal, nytimes, IBM (Watson), Spotify, eBay, SoundCloud, Intuit, FormidableLabs, Automattic, Trivago and Microsoft have either fully or partially switched to Jest for their JavaScript testing needs. Thank you very much for giving this project a chance. We would also like to thank everyone who went to conferences and meetups to speak about Jest and to everyone who is writing blog posts about how Jest is or isn't working for them!
Here is what happened in the community in the last two months:
- Jason Bonta and Dmitrii Abramov redefined the “testing pyramid” we were talking a lot about at Facebook.
- jest-codemods now allows you to painlessly migrate from Mocha, Tape and Ava to Jest.
- The React team announced improvements to the react-test-renderer in 15.4.0.
- Orta Therox build an amazing vscode-jest integration and donated the code for editor support to Jest.
- Pavithra Kodmad is documenting Flipkarts adoption of Jest and shares some getting started tips.
- Kent C. Dodds wrote about migrating to Jest at Paypal and Jason Brown wrote about migrating to Jest as well.
- Ben McCormick wrote about saving time with Jest.
- Eric Clemmons wrote about snapshots and storybook integration.
- Edvin Erikson wrote about getting Tap output in Jest.
- jest-html can bring snapshot diffing to your browser.
- There were a few great conversations on hackernews about Jest.
- The community started a great discussion about the future of enzyme.
- Ruben Oostinga wrote about combining chai and Jest matchers.
- Emil Ong wrote about why “TDD'ing your frontend seems pointless”.
- Nate Hunzaker wrote about end-to-end testing with Jest and Nightmare.
- Using Jest with Angular just works according to Matthieu Lux.
- A fantastic conversation about the purpose of snapshot testing is happening right now.
- Dmitrii made a new music video with his metal band.
- lazyspec can help you create smoke tests quickly if you are introducing tests to an existing codebase.
- Patrick Stapfer did a lightning talk about vim and Jest.
- Mark Dalgleish was commenting on the value of snapshot testing.
New features, changes and fixes in Jest 17 & 18
Jest was initially created more than five years ago and as such an old framework it has accumulated some technical debt. This is why we tend to make breaking changes more often than may seem necessary: We believe it is important to incrementally reduce technical debt to ensure that Jest as a project stays maintainable long-term. We didn't announce Jest 17 in a blog post and if you haven't upgraded to it in the last month you may find the changelog useful.
- Breaking: Removed
pit
in favor ofit
ortest
andmockImpl
in favor ofjest.fn()
ormockImplementation
. - Breaking: Renamed
--jsonOutputFile
to--outputFile
. - Breaking: Updated
testRegex
to includetest.js
andspec.js
files. - Breaking: Replaced
scriptPreprocessor
with the newtransform
option. - Breaking: The
testResultsProcessor
function is now required to return the modified results. - Potentially Breaking: Properly resolve
snapshotSerializers
,setupFiles
,transform
,testRunner
andtestResultsProcessor
with a resolution algorithm instead of usingpath.resolve
. This mainly means that<rootDir>
is no longer needed for these options. - **Added: **
pretty-format
andjest-editor-support
were merged into Jest. - Added:
expect.any
,expect.anything
,expect.objectContaining
,expect.arrayContaining
,expect.stringMatching
. - **Added: **
--testResultsProcessor
is now exposed through the cli. - Added: Implemented file watching in
jest-haste-map
. - Added: Usage of Jest in watch mode can be hidden through
JEST_HIDE_USAGE
. - Added:
expect.assertions(number)
which will ensure that a specified amount of assertions is made in one test. - **Added: **
.toMatchSnapshot(?string)
feature to give snapshots a name. - **Added: **
toMatchObject
,toHaveProperty
,toHaveLength
matchers. - Added:
expect.extend
. - Added: Added support for custom snapshots serializers.
- Added: Big diffs are now collapsed by default in snapshots and assertions. Added
--expand
(or-e
) to show the full diff. - Added:
jest.resetAllMocks
which replacesjest.clearAllMocks
. - **Added: **
--json
now includes information about individual tests inside a file. - **Fixed: **
test.concurrent
unhandled promise rejections. - Fixed:
babel-plugin-jest-hoist
when usingjest.mock
with three arguments. - Fixed: The
JSON
global injest-environment-node
now comes from the vm context instead of the parent context. - Fixed: Jest does not print stack traces from babel any longer.
- Fixed: Fake timers are reset when
FakeTimers.useTimers()
is called. - Fixed: Regular expressions are properly escaped in snapshots.
- Fixed: Improved pretty printing of large objects.
- Fixed:
NaN% Failed
in the OS notification when using--notify
. - Fixed: The first test run without cached timings will now use separate processes instead of running in band.
- Fixed:
Map
/Set
comparisons. - **Fixed: **
test.concurrent
now works with--testNamePattern
. - Fixed: Improved
.toContain
matcher. - Fixed: Properly resolve modules with platform extensions on react-native.
- Fixed: global built in objects in
jest-environment-node
now work properly. - Fixed: Create mock objects in the vm context instead of the parent context.
- **Fixed: **
.babelrc
is now part of the transform cache key inbabel-jest
. - Fixed: docblock parsing with haste modules.
- Fixed: Exit with the proper code when the coverage threshold is not reached.
- **Fixed: **Jest now clears the entire scrollback in watch mode.
- **Deprecated: **
jest-react-native
was deprecated and now forwardsreact-native
.
Plans for Jest in H1 2017
Six months ago we shared our plans for Jest and we are happy that we were able to execute well on almost all of them. For the next six months, here is what we are planning:
- Instant feedback: Nuclide integration and an improved and faster watch mode.
- Improved developer experience: new mocking APIs and improved assertions.
- Better performance and memory usage: analyze Jest and be more conscious about efficiency.
- **Snapshot Improvements: **snapshot approval mode, syntax highlighting and improved
react-test-renderer
APIs. - Website: We'll overhaul the website and documentation and add a Jest cheat sheet.
We won't be providing timelines or estimates for these features and we may not actually get to all of these things. If you'd like to help make these things a reality, send us issues and pull requests with your ideas and let's work on improving Jest together in 2017.