api-testing

API testing patterns with supertest, MSW, and Vitest. Covers integration testing for REST APIs, HTTP request mocking with Mock Service Worker v2, response assertions, schema validation, test organization, and framework-specific patterns for Express, Fastify, and Hono. Use when writing integration tests for REST APIs, mocking HTTP requests, or testing API endpoints. Use for api-test, supertest, msw, mock-service-worker, integration-test, http-mock, endpoint-test, request-test.

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "api-testing" with this command: npx skills add oakoss/agent-skills

API Testing

Overview

API testing validates HTTP endpoints by sending requests and asserting responses, covering status codes, headers, body content, and error handling. Supertest provides a fluent chainable API for integration testing against Express, Fastify, and Hono apps without starting a real server. MSW (Mock Service Worker) v2 intercepts outgoing HTTP requests at the network level, enabling realistic mocking of external services in both Node.js tests and browser environments.

When to use: Integration tests for REST APIs, testing middleware pipelines, validating request/response contracts, mocking third-party APIs in tests, testing error handling and edge cases.

When NOT to use: Unit testing pure functions (use direct assertions), E2E browser testing (use Playwright/Cypress), load/performance testing (use k6/Artillery), testing static file serving.

Quick Reference

PatternAPIKey Points
GET requestrequest(app).get('/path')Returns supertest Test object
POST with bodyrequest(app).post('/path').send(body)Automatically sets Content-Type
Auth header.set('Authorization', 'Bearer token')Chain before .expect()
Status assertion.expect(200)Chainable with body assertions
Body assertion.expect({ key: 'value' })Deep equality check
Header assertion.expect('Content-Type', /json/)Accepts string or regex
MSW HTTP handlerhttp.get('/api/users', resolver)Intercepts matching requests
MSW GraphQL handlergraphql.query('GetUser', resolver)Intercepts by operation name
MSW responseHttpResponse.json(data, { status })v2 response format
MSW error simulationHttpResponse.error()Simulates network failure
MSW one-time handlerhttp.get(path, resolver, { once: true })Auto-removed after first match
MSW per-test overrideserver.use(handler)Override default handlers in specific tests
Schema validationschema.parse(response.body)Validates response structure with Zod
Cookie persistenceconst agent = request.agent(app)Maintains cookies across requests
Fastify injectapp.inject({ method, url })Built-in testing without supertest
Hono test clienttestClient(app)Type-safe request builder

Common Mistakes

MistakeCorrect Pattern
Not awaiting supertest requestsAlways await request(app).get('/path')
Sharing server state between testsReset handlers with server.resetHandlers() in afterEach
Mocking fetch/axios directlyUse MSW to intercept at the network level
Forgetting server.listen() in setupCall in beforeAll, resetHandlers in afterEach
Passing Fastify instance to supertestUse fastify.server (the underlying Node server)
Asserting before response completesUse await or return the supertest chain
Hardcoding test data across many testsUse factories or fixtures for test data
Not testing error responsesTest 4xx and 5xx paths alongside happy paths
Using server.close() in afterEachUse afterAll for close, afterEach for reset only
Ignoring response headers in assertionsValidate Content-Type, Cache-Control, CORS headers
Not using onUnhandledRequest: 'error'Catch unhandled requests to prevent silent test gaps
Testing implementation instead of behaviorAssert on response shape, not internal function calls

Delegation

  • Test structure review: Use Task agent
  • Code review: Delegate to code-reviewer agent
  • Pattern discovery: Use Explore agent

If the vitest-testing skill is available, delegate general Vitest configuration and patterns to it. Otherwise, recommend: npx skills add oakoss/agent-skills --skill vitest-testing

References

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Automation

playwright

No summary provided by upstream source.

Repository SourceNeeds Review
Automation

ui-ux-polish

No summary provided by upstream source.

Repository SourceNeeds Review
Automation

tanstack-form

No summary provided by upstream source.

Repository SourceNeeds Review
Automation

find-skills

No summary provided by upstream source.

Repository SourceNeeds Review