Initial import from garrytan/gstack@026751e (main snapshot via local relay)
Some checks failed
Workflow Lint / actionlint (push) Has been cancelled
Build CI Image / build (push) Has been cancelled
Skill Docs Freshness / check-freshness (push) Has been cancelled
Periodic Evals / build-image (push) Has been cancelled
Periodic Evals / evals (map[file:test/codex-e2e.test.ts name:e2e-codex]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/gemini-e2e.test.ts name:e2e-gemini]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-design.test.ts name:e2e-design]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-plan.test.ts name:e2e-plan]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-qa-bugs.test.ts name:e2e-qa-bugs]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-qa-workflow.test.ts name:e2e-qa-workflow]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-review.test.ts name:e2e-review]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-workflow.test.ts name:e2e-workflow]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-routing-e2e.test.ts name:e2e-routing]) (push) Has been cancelled
Some checks failed
Workflow Lint / actionlint (push) Has been cancelled
Build CI Image / build (push) Has been cancelled
Skill Docs Freshness / check-freshness (push) Has been cancelled
Periodic Evals / build-image (push) Has been cancelled
Periodic Evals / evals (map[file:test/codex-e2e.test.ts name:e2e-codex]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/gemini-e2e.test.ts name:e2e-gemini]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-design.test.ts name:e2e-design]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-plan.test.ts name:e2e-plan]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-qa-bugs.test.ts name:e2e-qa-bugs]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-qa-workflow.test.ts name:e2e-qa-workflow]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-review.test.ts name:e2e-review]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-workflow.test.ts name:e2e-workflow]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-routing-e2e.test.ts name:e2e-routing]) (push) Has been cancelled
Source: https://github.com/garrytan/gstack/commit/026751e
This commit is contained in:
61
test/jargon-list.test.ts
Normal file
61
test/jargon-list.test.ts
Normal file
@@ -0,0 +1,61 @@
|
||||
/**
|
||||
* scripts/jargon-list.json — shape + content validation.
|
||||
*
|
||||
* This file is baked into generated SKILL.md prose at gen-skill-docs time.
|
||||
* Tests assert: valid JSON, expected shape, ~50 terms, no duplicates, no empty strings.
|
||||
*/
|
||||
import { describe, test, expect } from 'bun:test';
|
||||
import * as fs from 'fs';
|
||||
import * as path from 'path';
|
||||
|
||||
const ROOT = path.resolve(import.meta.dir, '..');
|
||||
const JARGON_PATH = path.join(ROOT, 'scripts', 'jargon-list.json');
|
||||
|
||||
describe('jargon-list.json', () => {
|
||||
test('file exists + parses as JSON', () => {
|
||||
expect(fs.existsSync(JARGON_PATH)).toBe(true);
|
||||
expect(() => JSON.parse(fs.readFileSync(JARGON_PATH, 'utf-8'))).not.toThrow();
|
||||
});
|
||||
|
||||
test('has expected top-level shape', () => {
|
||||
const data = JSON.parse(fs.readFileSync(JARGON_PATH, 'utf-8'));
|
||||
expect(data).toHaveProperty('version');
|
||||
expect(data).toHaveProperty('description');
|
||||
expect(data).toHaveProperty('terms');
|
||||
expect(Array.isArray(data.terms)).toBe(true);
|
||||
expect(typeof data.version).toBe('number');
|
||||
});
|
||||
|
||||
test('contains ~50 terms (±20 tolerance)', () => {
|
||||
const data = JSON.parse(fs.readFileSync(JARGON_PATH, 'utf-8'));
|
||||
expect(data.terms.length).toBeGreaterThanOrEqual(30);
|
||||
expect(data.terms.length).toBeLessThanOrEqual(80);
|
||||
});
|
||||
|
||||
test('all terms are non-empty strings', () => {
|
||||
const data = JSON.parse(fs.readFileSync(JARGON_PATH, 'utf-8'));
|
||||
for (const t of data.terms) {
|
||||
expect(typeof t).toBe('string');
|
||||
expect(t.trim().length).toBeGreaterThan(0);
|
||||
}
|
||||
});
|
||||
|
||||
test('no duplicate terms (case-insensitive)', () => {
|
||||
const data = JSON.parse(fs.readFileSync(JARGON_PATH, 'utf-8'));
|
||||
const seen = new Set<string>();
|
||||
for (const t of data.terms) {
|
||||
const key = t.toLowerCase();
|
||||
expect(seen.has(key)).toBe(false);
|
||||
seen.add(key);
|
||||
}
|
||||
});
|
||||
|
||||
test('includes common high-signal terms', () => {
|
||||
const data = JSON.parse(fs.readFileSync(JARGON_PATH, 'utf-8'));
|
||||
const terms = new Set(data.terms.map((t: string) => t.toLowerCase()));
|
||||
// Sanity: the list should include some canonical gstack-review jargon
|
||||
expect(terms.has('idempotent') || terms.has('idempotency')).toBe(true);
|
||||
expect(terms.has('race condition')).toBe(true);
|
||||
expect(terms.has('n+1') || terms.has('n+1 query')).toBe(true);
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user