Mocking REST API
Imports
In our src/mocks/handlers.js
file let's import the essentials we need for mocking a REST API. They are grouped under the rest
namespace exposed by the library.
Import rest
from the msw
package:
1// src/mocks/handlers.js2import { rest } from 'msw'
Request handler
To handle a REST API request we need to specify its method, path, and a function that would return the mocked response.
In this tutorial we will be mocking a basic login flow for our user. This flow implies handling two requests:
POST /login
, to allow our user to log in;GET /user
, to return the information about the logged in user.
Create request handlers by calling rest[METHOD]
and providing a request path:
1// src/mocks/handlers.js2import { rest } from 'msw'34export const handlers = [5 // Handles a POST /login request6 rest.post('/login', null),78 // Handles a GET /user request9 rest.get('/user', null),10]
Response resolver
To respond to an intercepted request we have to specify a mocked response using a response resolver function.
Response resolver is a function that accepts the following arguments:
req
, an information about a matching request;res
, a functional utility to create the mocked response;ctx
, a group of functions that help to set a status code, headers, body, etc. of the mocked response.
Provide response resolvers to the previously defined request handlers:
1// src/mocks/handlers.js2import { rest } from 'msw'34export const handlers = [5 rest.post('/login', (req, res, ctx) => {6 // Persist user's authentication in the session7 sessionStorage.setItem('is-authenticated', true)89 return res(10 // Respond with a 200 status code11 ctx.status(200),12 )13 }),1415 rest.get('/user', (req, res, ctx) => {16 // Check if the user is authenticated in this session17 const isAuthenticated = sessionStorage.getItem('is-authenticated')1819 if (!isAuthenticated) {20 // If not authenticated, respond with a 403 error21 return res(22 ctx.status(403),23 ctx.json({24 errorMessage: 'Not authorized',25 }),26 )27 }2829 // If authenticated, return a mocked user details30 return res(31 ctx.status(200),32 ctx.json({33 username: 'admin',34 }),35 )36 }),37]
Utilize things like
sessionStorage
,localStorage
, or IndexedDB to handle more complex API scenarios and user interactions.
Next step
The request handlers are complete, yet there is one last step to perform: integrate the mocking.