Mock Service Worker (MSW) is an API mocking library for browser and Node.js.
Features
Seamless. A dedicated layer of requests interception at your disposal. Keep your application's code and tests unaware of whether something is mocked or not.
Deviation-free. Request the same production resources and test the actual behavior of your app. Augment an existing API, or design it as you go, when there is none.
Familiar & Powerful. Use Express-like routing syntax to capture outgoing requests. Use parameters, wildcards, and regular expressions to match requests, and respond with necessary status codes, headers, cookies, delays, or completely custom resolvers.
"I found MSW and was thrilled that not only could I still see the mocked responses in my DevTools, but that the mocks didn't have to be written in a Service Worker and could instead live alongside the rest of my app. This made it silly easy to adopt. The fact that I can use it for testing as well makes MSW a huge productivity booster."
Browser usage is what sets Mock Service Worker apart from other tools. Utilizing the Service Worker API, which can intercept requests for the purpose of caching, Mock Service Worker responds to captured requests with your mock definition on the network level. This way your application knows nothing about the mocking.
Watch a 30 seconds explanation on how Mock Service Worker works in a browser:
How is it different?
Intercepts requests on the network level, not the application level.
If you think of your application as a box, Mock Service Worker lives in its own box next to yours, instead of opening and altering it for the purpose of mocking.
Agnostic of request-issuing libraries, so you can use it with fetch, axios, react-query, you-name-it.
The same mock definition can be reused for unit, integration, E2E testing, and debugging.
Performing a GET https://github.com/octocat request in your application will result into a mocked response that you can inspect in your browser's "Network" tab:
Tip: Did you know that although Service Worker runs in a separate thread, your mock definition executes on the client-side? That way you can use the same languages (i.e. TypeScript), third-party libraries, and internal logic in mocks.
Although Service Worker is a browser-specific API, this library allows reusing of the same mock definition to have API mocking in Node.js through augmenting native request issuing modules.
How is it different?
Prevents from stubbing fetch/axios/etc. as a part of your test, allowing you to treat API mocking as a pre-requisite and focus on what actually matters during testing.
The same mock definition you use for local development can be reused for testing.
Usage example
Here's an example of an actual integration test in Jest that uses React Testing Library and Mock Service Worker:
// test/LoginForm.test.jsimport'@testing-library/jest-dom'importReactfrom'react'import { rest } from'msw'import { setupServer } from'msw/node'import { render, screen } from'@testing-library/react'import userEvent from'@testing-library/user-event'importLoginfrom'../src/components/Login'const server = setupServer(
rest.post('/login', (req, res, ctx) => {
// Respond with a mocked user token that gets persisted// in the `sessionStorage` by the `Login` component.returnres(ctx.json({ token: 'mocked_user_token' }))
}),
)
// Enable API mocking before tests.beforeAll(() => server.listen())
// Reset any runtime request handlers we may add during the tests.afterEach(() => server.resetHandlers())
// Disable API mocking after the tests are done.afterAll(() => server.close())
test('allows the user to log in', async () => {
render(<Login />)
userEvent.type(
screen.getByRole('textbox', { name: /username/i }),
'john.maverick',
)
userEvent.type(
screen.getByRole('textbox', { name: /password/i }),
'super-secret',
)
userEvent.click(screen.getByText(/submit/i))
const alert = await screen.findByRole('alert')
// Assert successful login stateexpect(alert).toHaveTextContent(/welcome/i)
expect(window.sessionStorage.getItem('token')).toEqual(fakeUserResponse.token)
})
test('handles login exception', () => {
server.use(
rest.post('/login', (req, res, ctx) => {
// Respond with "500 Internal Server Error" status for this test.returnres(
ctx.status(500),
ctx.json({ message: 'Internal Server Error' }),
)
}),
)
render(<Login />)
userEvent.type(
screen.getByRole('textbox', { name: /username/i }),
'john.maverick',
)
userEvent.type(
screen.getByRole('textbox', { name: /password/i }),
'super-secret',
)
userEvent.click(screen.getByText(/submit/i))
// Assert meaningful error message shown to the userexpect(alert).toHaveTextContent(/sorry, something went wrong/i)
expect(window.sessionStorage.getItem('token')).toBeNull()
})
Tip: Did you know that although the API is called setupServer, there are no actual servers involved? The name is chosen for familiarity, and the API is designed to resemble operating with an actual server.
Sponsors
Golden Sponsors
Become our first golden sponsor and get featured right here, enjoying other perks like issue prioritization and a personal consulting session with us.
Seamless REST/GraphQL API mocking library for browser and Node.js.
The npm package @mattcosta7/msw receives a total of 1 weekly downloads. As such, @mattcosta7/msw popularity was classified as not popular.
We found that @mattcosta7/msw demonstrated a not healthy version release cadence and project activity because the last version was released a year ago.It has 1 open source maintainer collaborating on the project.
Package last updated on 02 Sep 2022
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Socket researchers have discovered malicious npm packages targeting crypto developers, stealing credentials and wallet data using spyware delivered through typosquats of popular cryptographic libraries.
A Stanford study reveals 9.5% of engineers contribute almost nothing, costing tech $90B annually, with remote work fueling the rise of "ghost engineers."