ktx/packages/cli/src/next-steps.test.ts

130 lines
4.4 KiB
TypeScript
Raw Normal View History

2026-05-10 23:12:26 +02:00
import { describe, expect, it } from 'vitest';
import {
2026-05-10 23:51:24 +02:00
KTX_CONTEXT_BUILD_COMMANDS,
KTX_NEXT_STEP_COMMANDS,
2026-05-10 23:12:26 +02:00
formatNextStepLines,
formatSetupNextStepLines,
} from './next-steps.js';
const command = (...parts: string[]) => parts.join(' ');
2026-05-10 23:51:24 +02:00
describe('KTX demo next steps', () => {
2026-05-10 23:12:26 +02:00
it('uses supported context-build commands before agent usage', () => {
2026-05-10 23:51:24 +02:00
expect(KTX_CONTEXT_BUILD_COMMANDS).toEqual([
2026-05-10 23:12:26 +02:00
{
2026-05-10 23:51:24 +02:00
command: 'ktx setup context build',
2026-05-10 23:12:26 +02:00
description: 'Build agent-ready context from configured primary and context sources',
},
{
2026-05-10 23:51:24 +02:00
command: 'ktx status',
2026-05-10 23:12:26 +02:00
description: 'Check setup and context readiness',
},
{
2026-05-10 23:51:24 +02:00
command: 'ktx setup context status',
2026-05-10 23:12:26 +02:00
description: 'Check the setup-managed context build state',
},
]);
});
it('uses supported final public commands', () => {
2026-05-10 23:51:24 +02:00
expect(KTX_NEXT_STEP_COMMANDS).toEqual([
2026-05-10 23:12:26 +02:00
{
2026-05-10 23:51:24 +02:00
command: 'ktx agent context --json',
2026-05-10 23:12:26 +02:00
description: 'Verify the project context your agent can read',
},
{
2026-05-10 23:51:24 +02:00
command: 'ktx agent tools --json',
2026-05-10 23:12:26 +02:00
description: 'List direct CLI tools available to agents',
},
{
2026-05-10 23:51:24 +02:00
command: 'ktx sl list',
2026-05-10 23:12:26 +02:00
description: 'Inspect generated semantic-layer sources',
},
{
2026-05-10 23:51:24 +02:00
command: 'ktx wiki list',
2026-05-10 23:12:26 +02:00
description: 'Inspect generated wiki pages',
},
{
2026-05-10 23:51:24 +02:00
command: 'ktx serve --mcp stdio --user-id local',
2026-05-10 23:12:26 +02:00
description: 'Optional MCP server route for clients that require MCP',
},
]);
});
it('prefers the direct CLI route before MCP serving', () => {
2026-05-10 23:51:24 +02:00
const commands = KTX_NEXT_STEP_COMMANDS.map((step) => step.command);
2026-05-10 23:12:26 +02:00
2026-05-10 23:51:24 +02:00
expect(commands.indexOf('ktx agent context --json')).toBeLessThan(
commands.indexOf('ktx serve --mcp stdio --user-id local'),
2026-05-10 23:12:26 +02:00
);
2026-05-10 23:51:24 +02:00
expect(commands.indexOf('ktx agent tools --json')).toBeLessThan(
commands.indexOf('ktx serve --mcp stdio --user-id local'),
2026-05-10 23:12:26 +02:00
);
});
it('explains what the next-step commands are for', () => {
const rendered = formatNextStepLines().join('\n');
2026-05-10 23:51:24 +02:00
expect(rendered).toContain('KTX context is ready for agents.');
2026-05-10 23:12:26 +02:00
expect(rendered).toContain('Preferred route: CLI + Skills');
expect(rendered).toContain('no MCP server is required');
expect(rendered).toContain('Direct CLI checks:');
expect(rendered).toContain('Optional MCP:');
2026-05-10 23:51:24 +02:00
expect(rendered).not.toContain('Ask your agent to use KTX');
2026-05-10 23:12:26 +02:00
});
it('does not advertise removed Commander migration commands', () => {
const rendered = formatNextStepLines().join('\n');
2026-05-10 23:51:24 +02:00
expect(rendered).toContain('ktx agent tools --json');
expect(rendered).toContain('ktx agent context --json');
expect(rendered).toContain('ktx sl list');
expect(rendered).toContain('ktx wiki list');
expect(rendered).toContain('ktx serve --mcp stdio --user-id local');
2026-05-10 23:12:26 +02:00
for (const removed of [
2026-05-10 23:51:24 +02:00
command('ktx', 'ask'),
command('ktx', 'mcp'),
command('ktx', 'connect'),
command('ktx', 'knowledge'),
2026-05-10 23:12:26 +02:00
command('dev', 'model'),
command('dev', 'knowledge'),
2026-05-10 23:51:24 +02:00
command('ktx', 'ingest', 'run'),
command('ktx', 'ingest', 'replay'),
2026-05-10 23:12:26 +02:00
]) {
expect(rendered).not.toContain(removed);
}
});
it('keeps setup next steps focused on building context when the build is not ready', () => {
const rendered = formatSetupNextStepLines({
setupReady: true,
hasContextTargets: true,
contextReady: false,
agentIntegrationReady: true,
}).join('\n');
2026-05-10 23:51:24 +02:00
expect(rendered).toContain('Build KTX context next.');
2026-05-10 23:12:26 +02:00
expect(rendered).toContain('primary-source scans and context-source ingests');
2026-05-10 23:51:24 +02:00
expect(rendered).toContain('ktx setup context build');
expect(rendered).toContain('ktx status');
expect(rendered).toContain('ktx setup context status');
expect(rendered).not.toContain('ktx agent context --json');
expect(rendered).not.toContain('ktx serve --mcp');
2026-05-10 23:12:26 +02:00
});
it('shows agent commands only after setup and context build are ready', () => {
const rendered = formatSetupNextStepLines({
setupReady: true,
hasContextTargets: true,
contextReady: true,
agentIntegrationReady: true,
}).join('\n');
2026-05-10 23:51:24 +02:00
expect(rendered).toContain('KTX context is ready for agents.');
expect(rendered).toContain('ktx agent context --json');
expect(rendered).toContain('ktx serve --mcp stdio --user-id local');
expect(rendered).not.toContain('Build KTX context next.');
2026-05-10 23:12:26 +02:00
});
});