AgentSkillsCN

code-quality

提供适用于多种语言与框架的通用代码质量与最佳实践指南。重点聚焦于代码静态分析、测试以及类型安全。

SKILL.md
--- frontmatter
name: code-quality
description: Provides general code quality and best practices guidance applicable across languages and frameworks. Focuses on linting, testing, and type safety.

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:

  • Ensure pnpm lint passes (no ESLint rule disables).
  • Ensure pnpm test passes (new features have tests).
  • Ensure pnpm build succeeds (no TypeScript errors).
  • 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):

typescript
describe('UserService', () => {
  it('should return user when found', async () => {
    // 1. Arrange (Mock dependencies)
    const mockRepo = { findByUid: jest.fn().mockResolvedValue(user) };
    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:

    typescript
    // 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

  • database-patterns/SKILL.md: N+1 queries, Soft Deletes, Bulk Operations.
  • service-pattern/SKILL.md: Business logic errors, Transactions.
  • repository-pattern/SKILL.md: Data access rules.
  • backend-controller-pattern-nestjs/SKILL.md: NestJS-specific controller rules.
  • frontend-code-quality/SKILL.md: React/Frontend specific patterns.