mirror of
https://github.com/Kaelio/ktx.git
synced 2026-06-10 08:05:14 +02:00
* docs(specs): design research-agent MCP tools and ktx mcp daemon Adds the 2026-05-14 design spec for exposing four new MCP tools (discover_data, entity_details, dictionary_search, sql_execution), shipping a ktx-research skill, and introducing an HTTP-only ktx mcp daemon so external agents can use KTX as a research-capable context layer. * Refine research-agent MCP tools spec after adversarial review iteration 1 * Refine research-agent MCP tools spec after adversarial review iteration 2 * Refine research-agent MCP tools spec after adversarial review iteration 3 * Refine spec: drop connectionName compat carve-out and ground summary/snippet provenance per kind * feat(daemon): validate read-only SQL with sqlglot * feat(context): expose read-only SQL validation port * feat(context): register MCP sql execution tool * feat(context): execute MCP SQL through validated connector path * test(context): update SQL analysis port fixtures * docs: add research-agent MCP sql execution foundation plan * feat(context): add scan-backed entity details service * feat(context): register MCP entity details tool * feat(context): expose local MCP entity details * test(context): align entity details scan fixtures * docs: add research-agent MCP entity_details plan * feat(context): add dictionary search service * feat(context): register MCP dictionary search tool * feat(context): expose local MCP dictionary search * docs: add research-agent MCP dictionary_search plan * feat: add MCP discover data service * feat: expose discover data MCP tool * feat: wire local discover data MCP port * docs: add research-agent MCP discover_data plan * feat(cli): add mcp http security helpers * feat(cli): host mcp over streamable http * feat(cli): manage mcp daemon lifecycle * feat(cli): add ktx mcp commands * fix(cli): stabilize mcp daemon verification * docs: add research-agent MCP http daemon plan * feat(cli): install KTX research skill * feat(cli): configure MCP clients in setup agents * feat(cli): support Claude local MCP setup scope * docs: add research-agent MCP setup-agents plan * refactor(context): use connectionId in warehouse verification tools * docs(context): update ingest verification prompts for connectionId * docs: add research-agent MCP ingest contract convergence plan * chore: build runtime artifacts in conductor setup --------- Co-authored-by: Andrey Avtomonov <7889985+andreybavt@users.noreply.github.com>
43 lines
1.9 KiB
TypeScript
43 lines
1.9 KiB
TypeScript
import { describe, expect, it } from 'vitest';
|
|
import { renderKtxCommandTree } from './print-command-tree.js';
|
|
|
|
describe('renderKtxCommandTree', () => {
|
|
it('renders an indented tree rooted at "ktx" with known top-level commands', () => {
|
|
const output = renderKtxCommandTree();
|
|
|
|
const lines = output.split('\n');
|
|
expect(lines[0]).toMatch(/^ktx( |$)/);
|
|
|
|
const topLevel = lines
|
|
.filter((line) => /^ {2}[├└]── \S/.test(line))
|
|
.map((line) => line.replace(/^ {2}[├└]── /, '').trim().split(' ')[0]);
|
|
|
|
for (const expected of ['setup', 'connection', 'ingest', 'sl', 'mcp', 'dev']) {
|
|
expect(topLevel).toContain(expected);
|
|
}
|
|
|
|
expect(output).toContain('│ └── test [connectionId]');
|
|
expect(output).toContain('│ ├── status Show KTX MCP daemon status');
|
|
expect(output).not.toContain('│ ├── add');
|
|
expect(output).not.toContain('│ ├── remove');
|
|
expect(output).not.toContain('│ ├── map');
|
|
expect(output).not.toContain('│ ├── mapping');
|
|
expect(output).not.toContain('│ ├── metabase');
|
|
expect(output).not.toContain('│ ├── notion');
|
|
expect(output).not.toContain('scan <connectionId>');
|
|
expect(output).not.toContain('│ ├── replay');
|
|
expect(output).not.toContain('│ └── replay');
|
|
expect(output).not.toContain('│ ├── run');
|
|
expect(output).not.toContain('│ ├── watch');
|
|
expect(output).not.toContain('│ └── watch');
|
|
expect(output).not.toContain('│ ├── read');
|
|
expect(output).not.toContain('│ ├── write');
|
|
expect(output).not.toContain('│ └── write');
|
|
});
|
|
|
|
it('ends with a single trailing newline', () => {
|
|
const output = renderKtxCommandTree();
|
|
expect(output.endsWith('\n')).toBe(true);
|
|
expect(output.endsWith('\n\n')).toBe(false);
|
|
});
|
|
});
|