mirror of
https://github.com/Kaelio/ktx.git
synced 2026-06-13 08:15:14 +02:00
* Improve schema setup and Notion ingest UX * Handle Postgres network scan failures * WIP: save local changes before main merge * Refine setup prompt choices * Tighten ingest reconciliation guidance * Commit setup config updates * Canonicalize unmapped fallback details * Count reconciliation actions in reports * Harden semantic layer source validation * Return wiki content after edits * Validate SL sources against manifests * Validate wiki refs before writes * Simplify CLI next steps * Clarify agent setup summary * Surface dbt target SL sources * Recover SL write fallbacks * Preserve failed context build metadata * Track raw paths for ingest actions * test(cli): update seeded demo expectations * fix(ingest): scope fallback recovery checks * fix(sl): tighten source validation guards * fix(wiki): ignore empty embedding vectors * Improve Notion ingest UX * Enforce flat wiki keys * test(context): update wiki key assertion --------- Co-authored-by: Andrey Avtomonov <andreybavt@gmail.com>
128 lines
4.3 KiB
TypeScript
128 lines
4.3 KiB
TypeScript
import { describe, expect, it } from 'vitest';
|
|
import {
|
|
KTX_CONTEXT_BUILD_COMMANDS,
|
|
KTX_NEXT_STEP_COMMANDS,
|
|
formatNextStepLines,
|
|
formatSetupNextStepLines,
|
|
} from './next-steps.js';
|
|
|
|
const command = (...parts: string[]) => parts.join(' ');
|
|
|
|
describe('KTX demo next steps', () => {
|
|
it('uses supported context-build commands before agent usage', () => {
|
|
expect(KTX_CONTEXT_BUILD_COMMANDS).toEqual([
|
|
{
|
|
command: 'ktx setup context build',
|
|
description: 'Build agent-ready context from configured primary and context sources',
|
|
},
|
|
{
|
|
command: 'ktx status',
|
|
description: 'Check setup and context readiness',
|
|
},
|
|
{
|
|
command: 'ktx setup context status',
|
|
description: 'Check the setup-managed context build state',
|
|
},
|
|
]);
|
|
});
|
|
|
|
it('uses supported final public commands', () => {
|
|
expect(KTX_NEXT_STEP_COMMANDS).toEqual([
|
|
{
|
|
command: 'ktx agent context --json',
|
|
description: 'Verify the project context your agent can read',
|
|
},
|
|
{
|
|
command: 'ktx agent tools --json',
|
|
description: 'List direct CLI tools available to agents',
|
|
},
|
|
{
|
|
command: 'ktx sl list',
|
|
description: 'Inspect generated semantic-layer sources',
|
|
},
|
|
{
|
|
command: 'ktx wiki list',
|
|
description: 'Inspect generated wiki pages',
|
|
},
|
|
{
|
|
command: 'ktx serve --mcp stdio --user-id local',
|
|
description: 'Optional MCP server route for clients that require MCP',
|
|
},
|
|
]);
|
|
});
|
|
|
|
it('prefers the direct CLI route before MCP serving', () => {
|
|
const commands = KTX_NEXT_STEP_COMMANDS.map((step) => step.command);
|
|
|
|
expect(commands.indexOf('ktx agent context --json')).toBeLessThan(
|
|
commands.indexOf('ktx serve --mcp stdio --user-id local'),
|
|
);
|
|
expect(commands.indexOf('ktx agent tools --json')).toBeLessThan(
|
|
commands.indexOf('ktx serve --mcp stdio --user-id local'),
|
|
);
|
|
});
|
|
|
|
it('explains what the next-step commands are for', () => {
|
|
const rendered = formatNextStepLines().join('\n');
|
|
|
|
expect(rendered).toContain('KTX context is ready for agents.');
|
|
expect(rendered).toContain('ask a data question');
|
|
expect(rendered).toContain('Verify with:');
|
|
expect(rendered).not.toContain('Preferred route');
|
|
expect(rendered).not.toContain('Optional MCP:');
|
|
});
|
|
|
|
it('does not advertise removed Commander migration commands', () => {
|
|
const rendered = formatNextStepLines().join('\n');
|
|
|
|
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');
|
|
|
|
for (const removed of [
|
|
command('ktx', 'ask'),
|
|
command('ktx', 'mcp'),
|
|
command('ktx', 'connect'),
|
|
command('ktx', 'knowledge'),
|
|
command('dev', 'model'),
|
|
command('dev', 'knowledge'),
|
|
command('ktx', 'ingest', 'run'),
|
|
command('ktx', 'ingest', 'replay'),
|
|
command('ktx', 'serve', '--mcp', 'stdio', '--user-id', 'local'),
|
|
]) {
|
|
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');
|
|
|
|
expect(rendered).toContain('Build KTX context next.');
|
|
expect(rendered).toContain('primary-source scans and context-source ingests');
|
|
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');
|
|
});
|
|
|
|
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');
|
|
|
|
expect(rendered).toContain('KTX context is ready for agents.');
|
|
expect(rendered).toContain('ktx agent context --json');
|
|
expect(rendered).not.toContain('ktx serve --mcp stdio --user-id local');
|
|
expect(rendered).not.toContain('Build KTX context next.');
|
|
});
|
|
});
|