mirror of
https://github.com/Kaelio/ktx.git
synced 2026-06-13 08:15:14 +02:00
* feat: add telemetry phase 1
* feat: add node telemetry event catalog
* feat: add telemetry event helpers
* feat: emit setup and connection telemetry
* feat: emit connection and stack telemetry
* feat: emit ingest and scan telemetry
* feat: emit query telemetry
* feat: emit sampled mcp telemetry
* docs: expand telemetry event catalog
* feat: add telemetry schema sync artifact
* feat: pass telemetry project id to semantic daemon
* feat: add daemon telemetry foundation
* feat: emit semantic daemon telemetry
* feat: emit daemon lifecycle telemetry
* docs: document full telemetry event catalog
* feat(telemetry): dim first-run notice
* feat(telemetry): show first-run notice before command output
* feat(telemetry): wire ktx PostHog project for live ingestion
* docs(telemetry): drop posthog project name and host from storage section
* docs(telemetry): trim to general overview and disclaimer
* docs(agents): add short telemetry guidelines
* feat(telemetry): enable posthog geoip enrichment
* docs(telemetry): drop ip-geoip note from public overview
* refactor(telemetry): drop no-op groupIdentify, rely on capture groups field
* fix(telemetry): respect CI kill switch in python daemon identity
* fix(sql): route table-count analysis to existing analyze-batch endpoint
* fix(telemetry): emit install_first_run from notice path and derive flagsPresent from commander
* fix(telemetry): read package info via getKtxCliPackageInfo to satisfy boundary check
* fix(telemetry): make python identity env={} bypass os.environ and unset CI in tests
* fix(telemetry): unset CI kill switch in cli-program-telemetry tests
37 lines
1 KiB
TypeScript
37 lines
1 KiB
TypeScript
import { describe, expect, it } from 'vitest';
|
|
|
|
import { beginCommandSpan, completeCommandSpan, resetCommandSpan } from './command-hook.js';
|
|
|
|
describe('telemetry command hook', () => {
|
|
it('builds a completed command event from a span', () => {
|
|
resetCommandSpan();
|
|
beginCommandSpan({
|
|
commandPath: ['ktx', 'status'],
|
|
flagsPresent: { projectDir: true, json: true },
|
|
projectDir: '/tmp/private',
|
|
hasProject: true,
|
|
attachProjectGroup: true,
|
|
startedAt: 100,
|
|
});
|
|
|
|
expect(
|
|
completeCommandSpan({
|
|
completedAt: 125,
|
|
outcome: 'ok',
|
|
}),
|
|
).toEqual({
|
|
commandPath: ['ktx', 'status'],
|
|
durationMs: 25,
|
|
outcome: 'ok',
|
|
flagsPresent: { projectDir: true, json: true },
|
|
hasProject: true,
|
|
projectDir: '/tmp/private',
|
|
projectGroupAttached: true,
|
|
});
|
|
});
|
|
|
|
it('returns undefined when no preAction span exists', () => {
|
|
resetCommandSpan();
|
|
expect(completeCommandSpan({ completedAt: 200, outcome: 'ok' })).toBeUndefined();
|
|
});
|
|
});
|