mirror of
https://github.com/glittercowboy/get-shit-done
synced 2026-04-25 17:25:23 +02:00
Add CURSOR_SESSION_ID env var detection in review.md so Cursor skips itself as a reviewer (matching the CLAUDE_CODE_ENTRYPOINT pattern). Add Qwen Review and Cursor Review sections to the REVIEWS.md template. Update ja-JP and ko-KR FEATURES.md to include --opencode, --qwen, and --cursor flags in the /gsd-review command signature. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
223 lines
6.7 KiB
JavaScript
223 lines
6.7 KiB
JavaScript
/**
|
|
* Cursor CLI Reviewer Tests (#1960)
|
|
*
|
|
* Verifies that /gsd-review includes Cursor CLI as a peer reviewer:
|
|
* - review.md workflow contains cursor detection, flag parsing, self-detection, invocation
|
|
* - commands/gsd/review.md command file mentions --cursor flag
|
|
* - help.md lists --cursor in the /gsd-review signature
|
|
* - docs/COMMANDS.md has --cursor flag row
|
|
* - docs/FEATURES.md has Cursor in the review section
|
|
* - i18n docs mirror the same content
|
|
* - REVIEWS.md template includes Cursor Review section
|
|
*/
|
|
|
|
const { test, describe } = require('node:test');
|
|
const assert = require('node:assert/strict');
|
|
const fs = require('fs');
|
|
const path = require('path');
|
|
|
|
const ROOT = path.join(__dirname, '..');
|
|
|
|
describe('Cursor CLI reviewer in /gsd-review (#1960)', () => {
|
|
|
|
// --- review.md workflow ---
|
|
|
|
describe('review.md workflow', () => {
|
|
const reviewPath = path.join(ROOT, 'get-shit-done', 'workflows', 'review.md');
|
|
let content;
|
|
|
|
test('review.md exists', () => {
|
|
assert.ok(fs.existsSync(reviewPath), 'review.md should exist');
|
|
content = fs.readFileSync(reviewPath, 'utf-8');
|
|
});
|
|
|
|
test('contains cursor CLI detection via command -v', () => {
|
|
const c = fs.readFileSync(reviewPath, 'utf-8');
|
|
assert.ok(
|
|
c.includes('command -v cursor'),
|
|
'review.md should detect cursor CLI via "command -v cursor"'
|
|
);
|
|
});
|
|
|
|
test('contains --cursor flag parsing', () => {
|
|
const c = fs.readFileSync(reviewPath, 'utf-8');
|
|
assert.ok(
|
|
c.includes('--cursor'),
|
|
'review.md should parse --cursor flag'
|
|
);
|
|
});
|
|
|
|
test('contains CURSOR_SESSION_ID self-detection', () => {
|
|
const c = fs.readFileSync(reviewPath, 'utf-8');
|
|
assert.ok(
|
|
c.includes('CURSOR_SESSION_ID'),
|
|
'review.md should detect self-CLI via CURSOR_SESSION_ID env var'
|
|
);
|
|
});
|
|
|
|
test('contains cursor agent invocation command', () => {
|
|
const c = fs.readFileSync(reviewPath, 'utf-8');
|
|
assert.ok(
|
|
c.includes('cursor agent -p --mode ask --trust'),
|
|
'review.md should invoke cursor via "cursor agent -p --mode ask --trust"'
|
|
);
|
|
});
|
|
|
|
test('contains Cursor Review section in REVIEWS.md template', () => {
|
|
const c = fs.readFileSync(reviewPath, 'utf-8');
|
|
assert.ok(
|
|
c.includes('Cursor Review'),
|
|
'review.md should include a "Cursor Review" section in the REVIEWS.md template'
|
|
);
|
|
});
|
|
|
|
test('lists cursor in the reviewers frontmatter array', () => {
|
|
const c = fs.readFileSync(reviewPath, 'utf-8');
|
|
assert.ok(
|
|
/reviewers:.*cursor/.test(c),
|
|
'review.md should list cursor in the reviewers array'
|
|
);
|
|
});
|
|
});
|
|
|
|
// --- commands/gsd/review.md ---
|
|
|
|
describe('commands/gsd/review.md', () => {
|
|
const cmdPath = path.join(ROOT, 'commands', 'gsd', 'review.md');
|
|
|
|
test('mentions --cursor flag', () => {
|
|
const c = fs.readFileSync(cmdPath, 'utf-8');
|
|
assert.ok(
|
|
c.includes('--cursor'),
|
|
'commands/gsd/review.md should mention --cursor flag'
|
|
);
|
|
});
|
|
|
|
test('mentions Cursor in objective or context', () => {
|
|
const c = fs.readFileSync(cmdPath, 'utf-8');
|
|
assert.ok(
|
|
c.includes('Cursor'),
|
|
'commands/gsd/review.md should mention Cursor'
|
|
);
|
|
});
|
|
});
|
|
|
|
// --- help.md ---
|
|
|
|
describe('help.md', () => {
|
|
const helpPath = path.join(ROOT, 'get-shit-done', 'workflows', 'help.md');
|
|
|
|
test('lists --cursor in /gsd-review signature', () => {
|
|
const c = fs.readFileSync(helpPath, 'utf-8');
|
|
assert.ok(
|
|
c.includes('--cursor'),
|
|
'help.md should list --cursor in the /gsd-review command signature'
|
|
);
|
|
});
|
|
});
|
|
|
|
// --- docs/COMMANDS.md ---
|
|
|
|
describe('docs/COMMANDS.md', () => {
|
|
const docsPath = path.join(ROOT, 'docs', 'COMMANDS.md');
|
|
|
|
test('has --cursor flag row', () => {
|
|
const c = fs.readFileSync(docsPath, 'utf-8');
|
|
assert.ok(
|
|
c.includes('--cursor'),
|
|
'docs/COMMANDS.md should have a --cursor flag row'
|
|
);
|
|
});
|
|
});
|
|
|
|
// --- docs/FEATURES.md ---
|
|
|
|
describe('docs/FEATURES.md', () => {
|
|
const featPath = path.join(ROOT, 'docs', 'FEATURES.md');
|
|
|
|
test('has --cursor in review command signature', () => {
|
|
const c = fs.readFileSync(featPath, 'utf-8');
|
|
assert.ok(
|
|
c.includes('--cursor'),
|
|
'docs/FEATURES.md should include --cursor in the review command signature'
|
|
);
|
|
});
|
|
|
|
test('mentions Cursor in the review purpose', () => {
|
|
const c = fs.readFileSync(featPath, 'utf-8');
|
|
assert.ok(
|
|
c.includes('Cursor'),
|
|
'docs/FEATURES.md should mention Cursor in the review section'
|
|
);
|
|
});
|
|
});
|
|
|
|
// --- i18n: ja-JP ---
|
|
|
|
describe('docs/ja-JP/COMMANDS.md', () => {
|
|
const jaPath = path.join(ROOT, 'docs', 'ja-JP', 'COMMANDS.md');
|
|
|
|
test('has --cursor flag row', () => {
|
|
const c = fs.readFileSync(jaPath, 'utf-8');
|
|
assert.ok(
|
|
c.includes('--cursor'),
|
|
'docs/ja-JP/COMMANDS.md should have a --cursor flag row'
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('docs/ja-JP/FEATURES.md', () => {
|
|
const jaPath = path.join(ROOT, 'docs', 'ja-JP', 'FEATURES.md');
|
|
|
|
test('has --cursor in review command signature', () => {
|
|
const c = fs.readFileSync(jaPath, 'utf-8');
|
|
assert.ok(
|
|
c.includes('--cursor'),
|
|
'docs/ja-JP/FEATURES.md should include --cursor in the review command signature'
|
|
);
|
|
});
|
|
|
|
test('mentions Cursor in the review section', () => {
|
|
const c = fs.readFileSync(jaPath, 'utf-8');
|
|
assert.ok(
|
|
/Cursor/i.test(fs.readFileSync(jaPath, 'utf-8')),
|
|
'docs/ja-JP/FEATURES.md should mention Cursor in the review section'
|
|
);
|
|
});
|
|
});
|
|
|
|
// --- i18n: ko-KR ---
|
|
|
|
describe('docs/ko-KR/COMMANDS.md', () => {
|
|
const koPath = path.join(ROOT, 'docs', 'ko-KR', 'COMMANDS.md');
|
|
|
|
test('has --cursor flag row', () => {
|
|
const c = fs.readFileSync(koPath, 'utf-8');
|
|
assert.ok(
|
|
c.includes('--cursor'),
|
|
'docs/ko-KR/COMMANDS.md should have a --cursor flag row'
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('docs/ko-KR/FEATURES.md', () => {
|
|
const koPath = path.join(ROOT, 'docs', 'ko-KR', 'FEATURES.md');
|
|
|
|
test('has --cursor in review command signature', () => {
|
|
const c = fs.readFileSync(koPath, 'utf-8');
|
|
assert.ok(
|
|
c.includes('--cursor'),
|
|
'docs/ko-KR/FEATURES.md should include --cursor in the review command signature'
|
|
);
|
|
});
|
|
|
|
test('mentions Cursor in the review section', () => {
|
|
const c = fs.readFileSync(koPath, 'utf-8');
|
|
assert.ok(
|
|
/Cursor/i.test(fs.readFileSync(koPath, 'utf-8')),
|
|
'docs/ko-KR/FEATURES.md should mention Cursor in the review section'
|
|
);
|
|
});
|
|
});
|
|
});
|