Use before any deployment or completion claim. Enforces test gates, evidence-based verification, and frontend safety checks. No deploy without passing. No claims without evidence.
From cmnpx claudepluginhub tody-agent/codymaster --plugin cmThis skill uses the workspace's default tool permissions.
Provides UI/UX resources: 50+ styles, color palettes, font pairings, guidelines, charts for web/mobile across React, Next.js, Vue, Svelte, Tailwind, React Native, Flutter. Aids planning, building, reviewing interfaces.
Fetches up-to-date documentation from Context7 for libraries and frameworks like React, Next.js, Prisma. Use for setup questions, API references, and code examples.
Implements distributed tracing with Jaeger/Tempo for microservices, including Kubernetes/Docker setup and OpenTelemetry instrumentation (Python/Flask). Use for debugging latency, dependencies, and request flows.
Three checkpoints, one skill: Pre-deploy testing, evidence verification, frontend safety.
test:gate.Goal: Identify the framework and install the correct testing dependencies.
package.json for framework (React, Vue, Astro, etc.) and wrangler.json(c).npm install -D vitest jsdom acornvitest.config.ts or vite.config.ts with environment: 'jsdom'.{
"scripts": {
"test:gate": "vitest run --reporter=verbose"
}
}
Do not combine these files. They form the "Quality Gate."
test/frontend-safety.test.ts)Prevents white screens, template corruption, and syntax errors.
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
});
test/api-routes.test.ts)Ensures backend endpoints respond correctly.
test/business-logic.test.ts)Tests pure functions, validations, and transformations.
test/i18n-sync.test.ts)Guarantees all language files have identical key counts.
ALWAYS run npm run test:gate before deploying. 0 failures required.
Check for skip override (explicit user words only):
Run test gate:
npm run test:gate
Parse results: total files, total tests, failures, duration
Gate decision:
| DON'T | DO |
|---|---|
| Deploy then test | Test then deploy |
| "Tests passed earlier" | Run fresh test:gate NOW |
| Skip for "small changes" | Every change gets tested |
| Run test + deploy parallel | Sequential: test → gate → deploy |
ALWAYS run the proving command before saying "fixed" or "done."
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
| Claim | Requires | Not Sufficient |
|---|---|---|
| Tests pass | Test output: 0 failures | "Should pass", previous run |
| Build succeeds | Build: exit 0 | Linter passing |
| Bug fixed | Test symptom: passes | Code changed, assumed fixed |
| Requirements met | Line-by-line checklist | Tests passing |
Automated via Layer 1 above.
Setting up or enhancing test suites for projects with frontend JavaScript/TypeScript.
| Layer | What it checks | Priority |
|---|---|---|
| 1. Syntax Validation | JS parses without errors (via acorn) | CRITICAL |
| 2. Function Integrity | Named functions exist and are callable | Required |
| 3. Template Safety | HTML templates have matching tags | Required |
| 4. Asset References | Referenced files actually exist | Required |
| 5. Corruption Patterns | Known bad patterns (empty functions, truncation) | Required |
| 6. Import/Export | Module references resolve | Recommended |
| 7. CSS Validation | CSS files parse correctly | Recommended |
npm install -D vitest acorn
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.
After ALL gates pass, update .cm/CONTINUITY.md:
verified or ready-to-deploy✅ Quality gate passed: [test count] tests, 0 failuresAfter ANY gate fails, FIRST run Memory Integrity Check:
.cm/meta-learnings.json if memory was the causeThen update .cm/CONTINUITY.md:
module:{failing-module} or global if systemicToken savings: Next session instantly knows if last run passed or failed without re-running the test suite just to check status.
| Skill | Relationship |
|---|---|
cm-safe-deploy | Quality gate is the primary blocker for the deploy pipeline |
cm-identity-guard | Verify identity before using quality gate to ship |
cm-tdd | TDD creates the logic for Layer 3 |
cm-safe-i18n | Leverages Layer 4 for parity checks |
cm-security-gate | PRE-REQUISITE for production: Security scan (Snyk + Aikido) PASS must be in deployment evidence. No production deploy without security clearance. |
| Evidence | Command | Required |
|---|---|---|
| Test suite passes | npm run test:gate | ✅ Always |
| Build succeeds | npm run build | ✅ Always |
| Security scan passes | snyk test && aikido-api-client scan-release ... | ✅ For production / public releases |
| i18n parity | Included in test:gate | ✅ If multilingual |
Test before deploy. Scan before release. Evidence before claims. Safety before shipping. Non-negotiable.