Agent Skill
2/7/2026

code-quality

Provides general code quality and best practices guidance applicable across languages and frameworks. Focuses on linting, testing, and type safety.

A
allenlin90
1GitHub Stars
1Views
npx skills add allenlin90/eridu-services

SKILL.md

Namecode-quality
DescriptionProvides general code quality and best practices guidance applicable across languages and frameworks. Focuses on linting, testing, and type safety.

name: code-quality description: Provides general code quality and best practices guidance applicable across languages and frameworks. Focuses on linting, testing, and type safety. Use when auditing code for quality issues, configuring linters, or enforcing type safety standards.

Code Quality Skill

Provides general code quality and best practices guidance applicable across languages and frameworks. Focuses on Linting, Testing, and Type Safety.

For architecture-specific patterns (N+1 queries, Soft Deletes, etc.), refer to:

Pre-Submission Checklist

Before marking any task as complete:

  • pnpm --filter <app> lint passes (no ESLint rule disables).
  • pnpm --filter <app> typecheck passes.
  • pnpm --filter <app> build succeeds — mandatory, stricter than typecheck alone.
  • pnpm --filter <app> test passes (new features have tests).
  • Avoid any / unknown types (maintain strict type safety).
  • Remove console.log statements (use a dedicated logger).
  • Ensure error messages are clear and actionable.

Linting

We use ESLint with strict rules.

  • Command: pnpm lint (or pnpm lint -- --fix)
  • Rule: NEVER disable rules with eslint-disable. Fix the underlying issue.

Common Fixes:

  • @typescript-eslint/no-explicit-any: Define a proper interface/DTO.
  • no-unused-vars: Remove the variable or prefix with _.
  • no-console: Inject a Logger service.

Testing

All new features require tests.

  • Unit Tests: Test individual classes (Services, Utils) with mocked dependencies.
  • Integration Tests: Test interactions (Repositories) with real database/services.

Example (Unit Test):

describe('UserService', () => {
  it('should return user when found', async () => {
    // 1. Arrange (Mock dependencies)
    const mockRepo = { findByUid: vi.fn().mockResolvedValue(user) };  // Vitest — not jest.fn()
    const service = new UserService(mockRepo as any);
 
    // 2. Act
    const result = await service.getUser('u_1');
 
    // 3. Assert
    expect(result).toEqual(user);
    expect(mockRepo.findByUid).toHaveBeenCalledWith('u_1');
  });
});

TypeScript Type Safety

Strict mode is enforced.

  • Avoid any / unknown:

    // BAD
    const data: any = req.body;
    
    // GOOD
    const data: CreateUserDto = req.body;
    
  • Use DTOs and Interfaces: Always define shapes for inputs and outputs.

  • Trust the Compiler: If it compiles, it should likely run (if types are accurate).

Common Anti-Patterns (General)

  1. Ignoring Lint Errors: Address them immediately.
  2. Logic in Controllers: Controllers should only handle HTTP req/res. Move logic to Services.
  3. Hardcoded Strings/Magic Numbers: Use constants or enums.
  4. Complex Conditionals: Break down complex if/else blocks into helper methods.
  5. Catch-All Error Handling: Avoid just using console.error. Handle specific errors or let global filters handle them.

Related Skills

Skills Info
Original Name:code-qualityAuthor:allenlin90