Agent Skills: NestJS Testing

Write Unit and E2E tests with Jest, mocking strategies, and database isolation in NestJS. Use when writing NestJS unit tests, E2E tests with supertest, or mock providers. (triggers: **/*.spec.ts, test/**/*.e2e-spec.ts, Test.createTestingModule, supertest, jest, beforeEach)

UncategorizedID: hoangnguyen0403/agent-skills-standard/nestjs-testing

Install this agent skill to your local

pnpm dlx add-skill https://github.com/HoangNguyen0403/agent-skills-standard/tree/HEAD/skills/nestjs/nestjs-testing

Skill Files

Browse the full folder contents for nestjs-testing.

Download Skill

Loading file tree…

skills/nestjs/nestjs-testing/SKILL.md

Skill Metadata

Name
nestjs-testing
Description
Write Unit and E2E tests with Jest, mocking strategies, and database isolation in NestJS. Use when writing NestJS unit tests, E2E tests with supertest, or mock providers.

NestJS Testing

Priority: P2 (MAINTENANCE)

Structure

src/**/*.spec.ts      # Unit tests (isolated logic)
test/**/*.e2e-spec.ts # E2E tests (full app flows)

Unit Testing

  • Setup: Use Test.createTestingModule() with mocked providers
  • Mocks: Mock all dependencies via { provide: X, useValue: mockX }
  • Pattern: AAA (Arrange-Act-Assert)
  • Cleanup: Call jest.clearAllMocks() in afterEach

E2E Testing

  • Database: Use real test DB (Docker). Never mock DB in E2E.
  • Cleanup: Mandatory. Use transaction rollback or TRUNCATE in afterEach.
  • App Init: Create app in beforeAll, close in afterAll
  • Guards: Override via .overrideGuard(X).useValue({ canActivate: () => true })

Strict TypeScript (MANDATORY)

  • No any: Use typed objects, jest.Mocked<T>, or as unknown as T. Never as any.
  • No eslint-disable: Fix underlying type issue. No exceptions.
  • Verify DTO shapes: Read actual DTO class before writing mock data.
  • Cast Jest matchers: Nested expect.anything()expect.anything() as unknown.
  • No unused vars: Only declare variables if referenced in assertions or setup.

Anti-Patterns

  • No Private Tests: Test via public methods, not service['privateMethod']. When coverage requires it, use typed helper (see strict-typescript reference).
  • No DB Mocks in E2E: Use real DB with cleanup. Mocks defeat E2E purpose.
  • No Shared State: Call jest.clearAllMocks() in afterEach. Random failures otherwise.
  • No Resource Leaks: Always close app and DB in afterAll.

References

Setup examples, mocking patterns, E2E flows, test builders, coverage config: references/patterns.md

Strict-TypeScript patterns (Jest matchers, mock typing, DTO verification): references/strict-typescript-testing.md