fix: refresh orchestration follow-up after #414 (#430)

This commit is contained in:
Affaan Mustafa
2026-03-16 14:29:28 -07:00
committed by GitHub
parent f0b394a151
commit f12bb90924
5 changed files with 416 additions and 55 deletions

View File

@@ -9,6 +9,7 @@ const {
slugify,
renderTemplate,
buildOrchestrationPlan,
executePlan,
materializePlan,
normalizeSeedPaths,
overlaySeedPaths
@@ -137,6 +138,64 @@ test('buildOrchestrationPlan normalizes global and worker seed paths', () => {
]);
});
test('buildOrchestrationPlan rejects worker names that collapse to the same slug', () => {
assert.throws(
() => buildOrchestrationPlan({
repoRoot: '/tmp/ecc',
sessionName: 'duplicates',
launcherCommand: 'echo run',
workers: [
{ name: 'Docs A', task: 'Fix skill docs' },
{ name: 'Docs/A', task: 'Fix tests' }
]
}),
/unique slugs/
);
});
test('buildOrchestrationPlan exposes shell-safe launcher aliases alongside raw defaults', () => {
const repoRoot = path.join('/tmp', 'My Repo');
const plan = buildOrchestrationPlan({
repoRoot,
sessionName: 'Spacing Audit',
launcherCommand: 'bash {repo_root_sh}/scripts/orchestrate-codex-worker.sh {task_file_sh} {handoff_file_sh} {status_file_sh} {worker_name_sh} {worker_name}',
workers: [{ name: 'Docs Fixer', task: 'Update docs' }]
});
const quote = value => `'${String(value).replace(/'/g, `'\\''`)}'`;
const resolvedRepoRoot = plan.workerPlans[0].repoRoot;
assert.ok(
plan.workerPlans[0].launchCommand.includes(`bash ${quote(resolvedRepoRoot)}/scripts/orchestrate-codex-worker.sh`),
'repo_root_sh should provide a shell-safe path'
);
assert.ok(
plan.workerPlans[0].launchCommand.includes(quote(plan.workerPlans[0].taskFilePath)),
'task_file_sh should provide a shell-safe path'
);
assert.ok(
plan.workerPlans[0].launchCommand.includes(`${quote(plan.workerPlans[0].workerName)} ${plan.workerPlans[0].workerName}`),
'raw defaults should remain available alongside shell-safe aliases'
);
});
test('buildOrchestrationPlan shell-quotes the orchestration banner command', () => {
const repoRoot = path.join('/tmp', "O'Hare Repo");
const plan = buildOrchestrationPlan({
repoRoot,
sessionName: 'Quote Audit',
launcherCommand: 'echo run',
workers: [{ name: 'Docs', task: 'Update docs' }]
});
const quote = value => `'${String(value).replace(/'/g, `'\\''`)}'`;
const bannerCommand = plan.tmuxCommands[1].args[3];
assert.strictEqual(
bannerCommand,
`printf '%s\\n' ${quote(`Session: ${plan.sessionName}`)} ${quote(`Coordination: ${plan.coordinationDir}`)}`,
'Banner command should quote coordination paths safely for tmux send-keys'
);
});
test('normalizeSeedPaths rejects paths outside the repo root', () => {
assert.throws(
() => normalizeSeedPaths(['../outside.txt'], '/tmp/ecc'),
@@ -229,5 +288,136 @@ test('overlaySeedPaths copies local overlays into the worker worktree', () => {
}
});
test('executePlan rolls back partial setup when orchestration fails mid-run', () => {
const plan = {
repoRoot: '/tmp/ecc',
sessionName: 'rollback-test',
coordinationDir: '/tmp/ecc/.orchestration/rollback-test',
replaceExisting: false,
workerPlans: [
{
workerName: 'Docs',
workerSlug: 'docs',
worktreePath: '/tmp/ecc-rollback-docs',
seedPaths: ['commands/orchestrate.md'],
gitArgs: ['worktree', 'add', '-b', 'orchestrator-rollback-test-docs', '/tmp/ecc-rollback-docs', 'HEAD'],
launchCommand: 'echo run'
}
]
};
const calls = [];
const rollbackCalls = [];
assert.throws(
() => executePlan(plan, {
spawnSync(program, args) {
calls.push({ type: 'spawnSync', program, args });
if (program === 'tmux' && args[0] === 'has-session') {
return { status: 1, stdout: '', stderr: '' };
}
throw new Error(`Unexpected spawnSync call: ${program} ${args.join(' ')}`);
},
runCommand(program, args) {
calls.push({ type: 'runCommand', program, args });
if (program === 'git' && args[0] === 'rev-parse') {
return { status: 0, stdout: 'true\n', stderr: '' };
}
if (program === 'tmux' && args[0] === '-V') {
return { status: 0, stdout: 'tmux 3.4\n', stderr: '' };
}
if (program === 'git' && args[0] === 'worktree') {
return { status: 0, stdout: '', stderr: '' };
}
throw new Error(`Unexpected runCommand call: ${program} ${args.join(' ')}`);
},
materializePlan(receivedPlan) {
calls.push({ type: 'materializePlan', receivedPlan });
},
overlaySeedPaths() {
throw new Error('overlay failed');
},
rollbackCreatedResources(receivedPlan, createdState) {
rollbackCalls.push({ receivedPlan, createdState });
}
}),
/overlay failed/
);
assert.deepStrictEqual(
rollbackCalls.map(call => call.receivedPlan),
[plan],
'executePlan should invoke rollback on failure'
);
assert.deepStrictEqual(
rollbackCalls[0].createdState.workerPlans,
plan.workerPlans,
'executePlan should only roll back resources created before the failure'
);
assert.ok(
calls.some(call => call.type === 'runCommand' && call.program === 'git' && call.args[0] === 'worktree'),
'executePlan should attempt setup before rolling back'
);
});
test('executePlan does not mark pre-existing resources for rollback when worktree creation fails', () => {
const plan = {
repoRoot: '/tmp/ecc',
sessionName: 'rollback-existing',
coordinationDir: '/tmp/ecc/.orchestration/rollback-existing',
replaceExisting: false,
workerPlans: [
{
workerName: 'Docs',
workerSlug: 'docs',
worktreePath: '/tmp/ecc-existing-docs',
seedPaths: [],
gitArgs: ['worktree', 'add', '-b', 'orchestrator-rollback-existing-docs', '/tmp/ecc-existing-docs', 'HEAD'],
launchCommand: 'echo run',
branchName: 'orchestrator-rollback-existing-docs'
}
]
};
const rollbackCalls = [];
assert.throws(
() => executePlan(plan, {
spawnSync(program, args) {
if (program === 'tmux' && args[0] === 'has-session') {
return { status: 1, stdout: '', stderr: '' };
}
throw new Error(`Unexpected spawnSync call: ${program} ${args.join(' ')}`);
},
runCommand(program, args) {
if (program === 'git' && args[0] === 'rev-parse') {
return { status: 0, stdout: 'true\n', stderr: '' };
}
if (program === 'tmux' && args[0] === '-V') {
return { status: 0, stdout: 'tmux 3.4\n', stderr: '' };
}
if (program === 'git' && args[0] === 'worktree') {
throw new Error('branch already exists');
}
throw new Error(`Unexpected runCommand call: ${program} ${args.join(' ')}`);
},
materializePlan() {},
rollbackCreatedResources(receivedPlan, createdState) {
rollbackCalls.push({ receivedPlan, createdState });
}
}),
/branch already exists/
);
assert.deepStrictEqual(
rollbackCalls[0].createdState.workerPlans,
[],
'Failures before creation should not schedule any worker resources for rollback'
);
assert.strictEqual(
rollbackCalls[0].createdState.sessionCreated,
false,
'Failures before tmux session creation should not mark a session for rollback'
);
});
console.log(`\n=== Results: ${passed} passed, ${failed} failed ===`);
if (failed > 0) process.exit(1);