mirror of
https://github.com/Kaelio/ktx.git
synced 2026-06-07 07:55:13 +02:00
* feat(completion): complete known argument values
* fix(completion): hide Commander-hidden subcommands from completions
Replace the `__`-prefix name heuristic with Commander's `_hidden` flag so
internal subcommands registered with { hidden: true } (e.g. `mcp serve-internal`)
are excluded from completions, mirroring `ktx --help`.
* test: cover wiki and sl read command routing
* test: cover raw wiki and sl reads
* feat: add wiki read command
* feat: add sl read command
* feat: complete read command entity names
* docs: document wiki and sl read commands
* test: include read commands in command tree
* feat(sl): read and validate unique sources by name
* feat(sl): make read and validate connection id optional
* fix(completion): dedupe semantic source names
* docs(sl): document connection-optional read and validate
* fix(sl): require connection id for query command
* docs(sl): clarify query connection requirement
* fix(completion): don't resolve option values as subcommands
resolveCommand skipped flag tokens but not the value consumed by a
value-taking option in the `--flag value` form, so a connection id like
`query` was matched as the `sl query` subcommand and yielded no `sl`
completions. Track value-taking options and skip their consumed value
before matching subcommands.
* test(telemetry): assert first-run notice via TELEMETRY_NOTICE constant
CI (which tests this branch merged with main) failed because #243 changed
the first-run notice wording in identity.ts (dropped "anonymous") but left
this test grepping for the old literal 'ktx collects anonymous usage data',
so indexOf returned -1. Assert against the exported TELEMETRY_NOTICE
constant instead so the test tracks the source of truth and cannot drift
when the notice text changes again.
20 lines
888 B
TypeScript
20 lines
888 B
TypeScript
import { describe, expect, it } from 'vitest';
|
|
import { completionScript } from '../../src/completion/completion-scripts.js';
|
|
|
|
describe('completionScript', () => {
|
|
it('emits a zsh script that registers _ktx and delegates to ktx __complete', () => {
|
|
const script = completionScript('zsh');
|
|
expect(script).toContain('#compdef ktx');
|
|
expect(script).toContain('compdef _ktx ktx');
|
|
expect(script).toContain('ktx __complete --');
|
|
expect(script).toContain('compadd -- $candidates');
|
|
});
|
|
|
|
it('emits a bash script that registers _ktx and preserves newline-split candidates', () => {
|
|
const script = completionScript('bash');
|
|
expect(script).toContain('complete -F _ktx ktx');
|
|
expect(script).toContain('ktx __complete --');
|
|
expect(script).toContain("local IFS=$'\\n'");
|
|
expect(script).toContain('COMPREPLY=($(compgen -W "${out}" -- "$cur"))');
|
|
});
|
|
});
|