testing-strategy

Generate tests following project conventions. Use when writing unit tests, integration tests, creating test fixtures, or implementing test builders. Triggers on requests like "write tests for", "add test coverage", "create test builder", "test this handler", or "implement tests".

$ Instalar

git clone https://github.com/haru01/sample_university_management_system /tmp/sample_university_management_system && cp -r /tmp/sample_university_management_system/backend/.claude/skills/testing-strategy ~/.claude/skills/sample_university_management_system

// tip: Run this command in your terminal to install the skill


name: testing-strategy description: Generate tests following project conventions. Use when writing unit tests, integration tests, creating test fixtures, or implementing test builders. Triggers on requests like "write tests for", "add test coverage", "create test builder", "test this handler", or "implement tests".

Testing Strategy

Generate and maintain tests following project-specific conventions for this .NET/EF Core DDD codebase.

Quick Reference

Test Pyramid

        +-------------+
        |  App Layer  |  Primary: Integration tests with SQLite in-memory
        |  Handlers   |  IAsyncLifetime pattern for isolation
        +-------------+
        |  Domain     |  Secondary: Unit tests for complex logic only
        |  Logic      |  Skip simple getters/setters
        +-------------+

Key Decisions

  • NO E2E tests - Application layer integration tests provide sufficient coverage
  • SQLite in-memory - Not EF Core InMemory provider (real constraints matter)
  • IAsyncLifetime - Each test method gets fresh DB instance
  • Builder pattern - Fluent builders with sensible defaults
  • Japanese test names - Describe behavior clearly

Test Implementation Guide

Step 1: Determine Test Type

LayerTest TypeWhen to Test
Application (CommandHandler)IntegrationAlways
Application (QueryHandler)IntegrationAlways
Domain (Aggregate)UnitComplex state transitions only
Domain (Service)UnitComplex business rules only
InfrastructureSkipCovered by Application tests

Step 2: Create Test Class

See references/patterns.md for complete templates:

  • Application Layer: IAsyncLifetime pattern with SQLite
  • Domain Layer: Simple unit test class

Step 3: Use Builders for Test Data

See references/builders.md for all available builders.

Key rules:

  • Single entity: use defaults
  • Multiple entities: MUST specify unique IDs

Step 4: Write Test Methods

See references/examples.md for common scenarios:

  • CommandHandler tests
  • QueryHandler with related data
  • Domain state transitions
  • Exception testing

Resources

FileContent
patterns.mdTemplates, builders, examples, anti-patterns
packages.mdNuGet packages and xUnit config

Anti-Patterns Summary

Anti-PatternCorrect Approach
Shared DbContextIAsyncLifetime with fresh DB
Constructor initInitializeAsync per test
Default IDs for multiple entitiesExplicit ID per entity
Testing simple gettersOnly test complex logic
E2E testsApplication layer integration

Repository

haru01
haru01
Author
haru01/sample_university_management_system/backend/.claude/skills/testing-strategy
0
Stars
0
Forks
Updated4h ago
Added1w ago