test(cli): add program context unit coverage

This commit is contained in:
Peter Steinberger
2026-02-21 20:08:35 +00:00
parent 0f36cbe677
commit d5bfbc36d8
2 changed files with 75 additions and 0 deletions

View File

@@ -0,0 +1,38 @@
import { Command } from "commander";
import { describe, expect, it } from "vitest";
import type { ProgramContext } from "./context.js";
import { getProgramContext, setProgramContext } from "./program-context.js";
function makeCtx(version: string): ProgramContext {
return {
programVersion: version,
channelOptions: ["telegram"],
messageChannelOptions: "telegram",
agentChannelOptions: "last|telegram",
};
}
describe("program context storage", () => {
it("stores and retrieves context on a command instance", () => {
const program = new Command();
const ctx = makeCtx("1.2.3");
setProgramContext(program, ctx);
expect(getProgramContext(program)).toBe(ctx);
});
it("returns undefined when no context was set", () => {
expect(getProgramContext(new Command())).toBeUndefined();
});
it("does not leak context between command instances", () => {
const programA = new Command();
const programB = new Command();
const ctxA = makeCtx("a");
const ctxB = makeCtx("b");
setProgramContext(programA, ctxA);
setProgramContext(programB, ctxB);
expect(getProgramContext(programA)).toBe(ctxA);
expect(getProgramContext(programB)).toBe(ctxB);
});
});