mirror of
https://github.com/Kaelio/ktx.git
synced 2026-06-13 08:15:14 +02:00
Align the tree with AGENTS.md/CLAUDE.md conventions: - Rewrite user-facing strings, docs, and tests to lowercase `ktx` (no bare uppercase `KTX` tokens remain outside literal identifiers). - Drop the legacy `historicSql` migration path and its now-unused helpers, per the no-backward-compat rule. - Remove `as unknown as` / `any` casts: narrow `BaseTool` generics to `z.ZodObject`, add a typed `createLookerClient`, and delete the dead `getParametersSchema`/`toAnthropicFormat` pre-AI-SDK helpers. - Use `InvalidArgumentError` for Commander parse failures. - Finish the adapter→connector prose conversion in the `ktx.yaml` docs while keeping the literal `adapters` config key.
53 lines
2.4 KiB
JavaScript
53 lines
2.4 KiB
JavaScript
import assert from 'node:assert/strict';
|
|
import { readFile } from 'node:fs/promises';
|
|
import { describe, it } from 'node:test';
|
|
|
|
async function readText(relativePath) {
|
|
return readFile(new URL(`../${relativePath}`, import.meta.url), 'utf8');
|
|
}
|
|
|
|
describe('Conductor workspace scripts', () => {
|
|
it('registers setup and run scripts in nonconcurrent mode', async () => {
|
|
const manifest = JSON.parse(await readText('conductor.json'));
|
|
|
|
assert.deepEqual(manifest.scripts, {
|
|
setup: 'bash scripts/conductor-setup.sh',
|
|
run: 'bash scripts/conductor-run.sh',
|
|
});
|
|
assert.equal(manifest.runScriptMode, 'nonconcurrent');
|
|
});
|
|
|
|
it('sets up exact uv, local files, Python packages, JS packages, and the built CLI', async () => {
|
|
const setupScript = await readText('scripts/conductor-setup.sh');
|
|
|
|
assert.match(setupScript, /read_required_uv_version\(\)/);
|
|
assert.match(setupScript, /\.context\/bin\/uv-\$required_version/);
|
|
assert.match(setupScript, /link_agent_overlays/);
|
|
assert.match(setupScript, /CONDUCTOR_ROOT_PATH/);
|
|
assert.match(setupScript, /uv sync --all-packages --all-groups/);
|
|
assert.match(setupScript, /pnpm install --frozen-lockfile --prefer-offline/);
|
|
assert.match(setupScript, /pnpm run native:rebuild/);
|
|
assert.match(setupScript, /pnpm run artifacts:build/);
|
|
assert.match(setupScript, /packages\/cli\/dist\/bin\.js/);
|
|
assert.match(setupScript, /status --no-input/);
|
|
assert.doesNotMatch(setupScript, /scripts\/conductor\//);
|
|
});
|
|
|
|
it('links private agent overlays from the Conductor root checkout', async () => {
|
|
const workspaceScript = await readText('scripts/conductor-setup.sh');
|
|
|
|
assert.match(workspaceScript, /link_shared_path "\$CONDUCTOR_ROOT_PATH\/\.agents" \.agents/);
|
|
assert.match(workspaceScript, /link_shared_path "\$CONDUCTOR_ROOT_PATH\/\.claude" \.claude/);
|
|
assert.doesNotMatch(workspaceScript, /KTX_AGENT_OVERLAYS_ROOT/);
|
|
assert.doesNotMatch(workspaceScript, /link_agent_skills_for_claude/);
|
|
});
|
|
|
|
it('runs the ktx daemon on the documented fixed local port', async () => {
|
|
const runScript = await readText('scripts/conductor-run.sh');
|
|
|
|
assert.match(runScript, /pnpm run build/);
|
|
assert.match(runScript, /source \.venv\/bin\/activate/);
|
|
assert.match(runScript, /uv run ktx-daemon serve-http --host 127\.0\.0\.1 --port 8765/);
|
|
assert.doesNotMatch(runScript, /\bnpx\b/);
|
|
});
|
|
});
|