Skip to content

๐Ÿ“‹ Full Skill Source โ€” This is the complete, unedited SKILL.md file. Nothing is hidden or summarized.

โ† Back to Skills Library

Quality Gate โ€” Test + Verify + Ship Safe โ€‹

Three checkpoints, one skill: Pre-deploy testing, evidence verification, frontend safety.

The Iron Laws โ€‹

  1. NO DEPLOY without passing test:gate.
  2. NO CLAIMS without fresh verification output.
  3. NO FRAGILE FRONTEND โ€” safety tests are mandatory.

Phase 0: Infrastructure Setup โ€‹

Goal: Identify the framework and install the correct testing dependencies.

  1. Detect Stack: Check package.json for framework (React, Vue, Astro, etc.) and wrangler.json(c).
  2. Install Deps: npm install -D vitest jsdom acorn
  3. Configure: Create vitest.config.ts or vite.config.ts with environment: 'jsdom'.
  4. Wire Scripts:
    json
    {
      "scripts": {
        "test:gate": "vitest run --reporter=verbose"
      }
    }

Phase 1: The 4 Core Test Layers โ€‹

Do not combine these files. They form the "Quality Gate."

Layer 1: Frontend Safety (test/frontend-safety.test.ts) โ€‹

Prevents white screens, template corruption, and syntax errors.

javascript
test('app.js does not contain catastrophic corruption', () => {
    const code = fs.readFileSync('public/static/app.js', 'utf-8');
    expect(code).not.toMatch(/=\s*'[^']*\$\{t\(/); // Bug #1
    expect(code).not.toMatch(/<\s+[a-zA-Z]/); // Bug #2
});

Layer 2: API Routes (test/api-routes.test.ts) โ€‹

Ensures backend endpoints respond correctly.

Layer 3: Business Logic (test/business-logic.test.ts) โ€‹

Tests pure functions, validations, and transformations.

Layer 4: i18n Synchronization (test/i18n-sync.test.ts) โ€‹

Guarantees all language files have identical key counts.


Phase 2: Execution (The Gates) โ€‹

Gate 1: Pre-Deploy Testing โ€‹

ALWAYS run npm run test:gate before deploying. 0 failures required.

Protocol โ€‹

  1. Check for skip override (explicit user words only):

    • โœ… "skip tests", "bแป qua test", "deploy without testing"
    • โŒ "deploy", "quick deploy", "just push it" (= tests required)
  2. Run test gate:

    bash
    npm run test:gate
  3. Parse results: total files, total tests, failures, duration

  4. Gate decision:

    • 0 failures โ†’ proceed to deploy
    • Any failures โ†’ STOP. Fix first. Do NOT deploy.

Anti-Patterns โ€‹

DON'TDO
Deploy then testTest then deploy
"Tests passed earlier"Run fresh test:gate NOW
Skip for "small changes"Every change gets tested
Run test + deploy parallelSequential: test โ†’ gate โ†’ deploy

Gate 2: Evidence Before Claims โ€‹

ALWAYS run the proving command before saying "fixed" or "done."

The Gate Function โ€‹

1. IDENTIFY โ†’ What command proves this claim?
2. RUN โ†’ Execute the FULL command (fresh)
3. READ โ†’ Full output, check exit code
4. VERIFY โ†’ Does output confirm the claim?
5. ONLY THEN โ†’ Make the claim

Common Failures โ€‹

ClaimRequiresNot Sufficient
Tests passTest output: 0 failures"Should pass", previous run
Build succeedsBuild: exit 0Linter passing
Bug fixedTest symptom: passesCode changed, assumed fixed
Requirements metLine-by-line checklistTests passing

Red Flags โ€” STOP โ€‹

  • Using "should", "probably", "seems to"
  • Expressing satisfaction before verification
  • Trusting agent success reports
  • ANY wording implying success without running verification

Gate 3: Frontend Integrity โ€‹

Automated via Layer 1 above.

When โ€‹

Setting up or enhancing test suites for projects with frontend JavaScript/TypeScript.

The 7 Layers โ€‹

LayerWhat it checksPriority
1. Syntax ValidationJS parses without errors (via acorn)CRITICAL
2. Function IntegrityNamed functions exist and are callableRequired
3. Template SafetyHTML templates have matching tagsRequired
4. Asset ReferencesReferenced files actually existRequired
5. Corruption PatternsKnown bad patterns (empty functions, truncation)Required
6. Import/ExportModule references resolveRecommended
7. CSS ValidationCSS files parse correctlyRecommended

Setup โ€‹

bash
npm install -D vitest acorn

Layer 1: Syntax Check (Most Critical) โ€‹

javascript
import { parse } from 'acorn';
import { readFileSync } from 'fs';

test('app.js has valid syntax', () => {
  const code = readFileSync('public/static/app.js', 'utf-8');
  expect(() => parse(code, { ecmaVersion: 2022, sourceType: 'script' })).not.toThrow();
});

This single test would have prevented the March 2026 white-screen incident.


Integration โ€‹

SkillRelationship
cm-safe-deployQuality gate is the primary blocker for the deploy pipeline
cm-identity-guardVerify identity before using quality gate to ship
cm-tddTDD creates the logic for Layer 3
cm-safe-i18nLeverages Layer 4 for parity checks

The Bottom Line โ€‹

Test before deploy. Evidence before claims. Safety before shipping. Non-negotiable.

Open Source AI Agent Skills Framework