This is a demo of how to use E2E testing with playwright with complete mocking (via recording) of external requests made both server side and client side.
Install the project dependencies as well as playwright browsers
npm i
npx playwright install
Run the development server. Next recommends running against production however to record coverage its necessary to use a development build, and in addition the recording and playback setup shown here is turned off for production.
npm run dev
Then you can run playwright tests with:
npx playwright test
Test external requests are not being made by:
- Turning off your network connection OR
- Setting RECORD=false in .env
Client side recording uses the built in playwright functionality. In test/playwright.js we set it up so that each recording is isolated to each individual test.
We use nock
to record requests made by the server in getStaticProps
. This is done with a wrapper test/helpers/wrap-static-props-for-tests.js that uses preview mode in order to get the test name to assign recordings to.
- Delete
test/helpers/wrap-static-props-for-tests.js
- Make sure you can connect to the internet and that RECORD=true
- Start the development server.
- Run the tests with playwright
npx playwright test
In the logs where you ran npm run dev, you should see "Recording ended for home_page_can_view_the_page (saved 0 recordings)"
Now delete test/helpers/wrap-static-props-for-tests.js
again.
Without restarting the server rerun the test.
You should see "Recording ended for home_page_can_view_the_page (saved 1 recordings)"
I'm not sure if this is by design but nock recording is returning the body in base64. See the compress/decompress utils added here: test/helpers/wrap-static-props-for-tests.js
. IMO Nock should be returning json bodies as objects.
Preview mode is deprecated in favor of draft mode. Draft mode however has no "previewData" which we need in order to be able to pass test names to test/helpers/wrap-static-props-for-tests.js
As far as I can see there is no other way to pass information at runtime to getStaticProps
.