()
| 17 | }) |
| 18 | |
| 19 | function activate() { |
| 20 | interceptor.apply() |
| 21 | |
| 22 | // Force msw to forward Nock's error instead of coerce it into 500 error |
| 23 | interceptor.on('unhandledException', ({ controller, error }) => { |
| 24 | controller.errorWith(error) |
| 25 | }) |
| 26 | interceptor.on('request', async function ({ request, controller }) { |
| 27 | if (request.headers.get('expect') === '100-continue') { |
| 28 | // We currently do not support mocking 100-continue responses, so they are passed through for now. |
| 29 | return |
| 30 | } |
| 31 | const rawRequest = getRawRequest(request) |
| 32 | |
| 33 | // If this is GET request with body, we need to read the body from the socket because Fetch API doesn't support this. |
| 34 | const requestBodyBuffer = common.decompressRequestBody( |
| 35 | rawRequest instanceof http.ClientRequest && |
| 36 | request.method === 'GET' && |
| 37 | request.headers.get('content-length') > 0 |
| 38 | ? await arrayBuffer(getClientRequestBodyStream(request)) |
| 39 | : await request.clone().arrayBuffer(), |
| 40 | request.headers.get('content-encoding') || '', |
| 41 | ) |
| 42 | |
| 43 | const decompressedRequest = new Request(request, { |
| 44 | body: |
| 45 | requestBodyBuffer.length > 0 && request.method !== 'GET' |
| 46 | ? requestBodyBuffer |
| 47 | : undefined, |
| 48 | }) |
| 49 | if (requestBodyBuffer.byteLength > 0 && request.method === 'GET') { |
| 50 | setDecompressedGetBody(decompressedRequest, requestBodyBuffer) |
| 51 | } |
| 52 | |
| 53 | const response = await handleRequest(decompressedRequest) |
| 54 | if (response) { |
| 55 | controller.respondWith(response) |
| 56 | } |
| 57 | }) |
| 58 | } |
| 59 | |
| 60 | function deactivate() { |
| 61 | interceptor.dispose() |
nothing calls this directly
no test coverage detected
searching dependent graphs…