Skip to content

Commit

Permalink
feat: print request body in onUnhandledRequest message (#2227)
Browse files Browse the repository at this point in the history
Co-authored-by: Artem Zakharchenko <[email protected]>
  • Loading branch information
bitttttten and kettanaito authored Aug 28, 2024
1 parent 78360c8 commit a2153c9
Show file tree
Hide file tree
Showing 5 changed files with 51 additions and 18 deletions.
28 changes: 28 additions & 0 deletions src/core/utils/request/onUnhandledRequest.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,15 @@ const fixtures = {
• GET ${url}
If you still wish to intercept this unhandled request, please create a request handler for it.
Read more: https://mswjs.io/docs/getting-started/mocks`,
warningWithResponseBody: (url = `/api`) => `\
[MSW] Warning: intercepted a request without a matching request handler:
• POST ${url}
• Request body: {\"variables\":{\"id\":\"abc-123\"},\"query\":\"query UserName($id: String!) { user(id: $id) { name } }\"}
If you still wish to intercept this unhandled request, please create a request handler for it.
Read more: https://mswjs.io/docs/getting-started/mocks`,

Expand Down Expand Up @@ -51,6 +60,25 @@ test('supports the "warn" request strategy', async () => {
)
})

test('supports the "warn" request strategy with request body', async () => {
await onUnhandledRequest(
new Request(new URL('http://localhost/api'), {
method: 'POST',
headers: {
'Content-Type': 'application/json',
},
body: JSON.stringify({
variables: {
id: 'abc-123',
},
query: 'query UserName($id: String!) { user(id: $id) { name } }',
}),
}),
)

expect(console.warn).toHaveBeenCalledWith(fixtures.warningWithResponseBody())
})

test('supports the "error" request strategy', async () => {
await expect(
onUnhandledRequest(new Request(new URL('http://localhost/api')), 'error'),
Expand Down
7 changes: 6 additions & 1 deletion src/core/utils/request/onUnhandledRequest.ts
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,12 @@ export async function onUnhandledRequest(
const url = new URL(request.url)
const publicUrl = toPublicUrl(url) + url.search

const unhandledRequestMessage = `intercepted a request without a matching request handler:\n\n \u2022 ${request.method} ${publicUrl}\n\nIf you still wish to intercept this unhandled request, please create a request handler for it.\nRead more: https://mswjs.io/docs/getting-started/mocks`
const requestBody =
request.method === 'HEAD' || request.method === 'GET'
? null
: await request.clone().text()
const messageDetails = `\n\n \u2022 ${request.method} ${publicUrl}\n\n${requestBody ? ` \u2022 Request body: ${requestBody}\n\n` : ''}`
const unhandledRequestMessage = `intercepted a request without a matching request handler:${messageDetails}If you still wish to intercept this unhandled request, please create a request handler for it.\nRead more: https://mswjs.io/docs/getting-started/mocks`

function applyStrategy(strategy: UnhandledRequestStrategy) {
switch (strategy) {
Expand Down
12 changes: 7 additions & 5 deletions test/browser/graphql-api/anonymous-operation.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -41,8 +41,8 @@ test('does not warn on anonymous GraphQL operation when no GraphQL handlers are

const endpointUrl = httpServer.http.url('/graphql')
const response = await query(endpointUrl, {
// Intentionally anonymous query.
query: gql`
# Intentionally anonymous query.
query {
user {
id
Expand Down Expand Up @@ -71,6 +71,8 @@ test('does not warn on anonymous GraphQL operation when no GraphQL handlers are
• POST ${endpointUrl}
• Request body: {\"query\":\"\\n query {\\n user {\\n id\\n }\\n }\\n \"}
If you still wish to intercept this unhandled request, please create a request handler for it.
Read more: https://mswjs.io/docs/getting-started/mocks`,
])
Expand Down Expand Up @@ -105,9 +107,9 @@ test('warns on handled anonymous GraphQL operation', async ({

const endpointUrl = httpServer.http.url('/graphql')
const response = await query(endpointUrl, {
// Intentionally anonymous query.
// It will be handled in the "graphql.operation()" handler above.
query: gql`
# Intentionally anonymous query.
# It will be handled in the "graphql.operation()" handler above.
query {
user {
id
Expand Down Expand Up @@ -170,9 +172,9 @@ test('does not print a warning on anonymous GraphQL operation handled by "graphq

const endpointUrl = httpServer.http.url('/graphql')
const response = await query(endpointUrl, {
// Intentionally anonymous query.
// It will be handled in the "graphql.operation()" handler above.
query: gql`
# Intentionally anonymous query.
# It will be handled in the "graphql.operation()" handler above.
query {
user {
id
Expand Down
11 changes: 5 additions & 6 deletions test/node/regressions/many-request-handlers-jsdom.test.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,4 @@
/**
* @vitest-environment jsdom
*/
// @vitest-environment jsdom
import { HttpServer } from '@open-draft/test-server/http'
import { graphql, http, HttpResponse } from 'msw'
import { setupServer } from 'msw/node'
Expand Down Expand Up @@ -74,8 +72,9 @@ describe('http handlers', () => {
body: 'request-body-',
},
)
// Each clone is a new AbortSignal listener which needs to be registered
expect(requestCloneSpy).toHaveBeenCalledTimes(1)
// Each clone is a new AbortSignal listener which needs to be registered.
// One clone is `onUnhandledRequest` reading the request body to print.
expect(requestCloneSpy).toHaveBeenCalledTimes(2)
expect(httpResponse.status).toBe(500)
expect(processErrorSpy).not.toHaveBeenCalled()
})
Expand Down Expand Up @@ -122,7 +121,7 @@ describe('graphql handlers', () => {
})

expect(unhandledResponse.status).toEqual(500)
expect(requestCloneSpy).toHaveBeenCalledTimes(2)
expect(requestCloneSpy).toHaveBeenCalledTimes(3)
// Must not print any memory leak warnings.
expect(processErrorSpy).not.toHaveBeenCalled()
})
Expand Down
11 changes: 5 additions & 6 deletions test/node/regressions/many-request-handlers.test.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,4 @@
/**
* @vitest-environment node
*/
// @vitest-environment node
import { HttpServer } from '@open-draft/test-server/http'
import { graphql, http, HttpResponse } from 'msw'
import { setupServer } from 'msw/node'
Expand Down Expand Up @@ -75,8 +73,9 @@ describe('http handlers', () => {
body: 'request-body-',
},
)
// Each clone is a new AbortSignal listener which needs to be registered
expect(requestCloneSpy).toHaveBeenCalledTimes(1)
// Each clone is a new AbortSignal listener which needs to be registered.
// One clone is `onUnhandledRequest` reading the request body to print.
expect(requestCloneSpy).toHaveBeenCalledTimes(2)
expect(httpResponse.status).toBe(500)
expect(stdErrSpy).not.toHaveBeenCalled()
})
Expand Down Expand Up @@ -124,7 +123,7 @@ describe('graphql handlers', () => {
})

expect(unhandledResponse.status).toEqual(500)
expect(requestCloneSpy).toHaveBeenCalledTimes(2)
expect(requestCloneSpy).toHaveBeenCalledTimes(3)
// Must not print any memory leak warnings.
expect(stdErrSpy).not.toHaveBeenCalled()
})
Expand Down

0 comments on commit a2153c9

Please sign in to comment.