CLI: streamline startup paths and env parsing
Add shared parseBooleanValue()/isTruthyEnvValue() and apply across CLI, gateway, memory, and live-test flags for consistent env handling. Introduce route-first fast paths, lazy subcommand registration, and deferred plugin loading to reduce CLI startup overhead. Centralize config validation via ensureConfigReady() and add config caching/deferred shell env fallback for fewer IO passes. Harden logger initialization/imports and add focused tests for argv, boolean parsing, frontmatter, and CLI subcommands.
This commit is contained in:
committed by
Peter Steinberger
parent
97531f174f
commit
acb523de86
@@ -1,6 +1,6 @@
|
||||
import { describe, expect, it } from "vitest";
|
||||
|
||||
import { normalizeZaiEnv } from "./env.js";
|
||||
import { isTruthyEnvValue, normalizeZaiEnv } from "./env.js";
|
||||
|
||||
describe("normalizeZaiEnv", () => {
|
||||
it("copies Z_AI_API_KEY to ZAI_API_KEY when missing", () => {
|
||||
@@ -35,3 +35,19 @@ describe("normalizeZaiEnv", () => {
|
||||
else process.env.Z_AI_API_KEY = prevZAi;
|
||||
});
|
||||
});
|
||||
|
||||
describe("isTruthyEnvValue", () => {
|
||||
it("accepts common truthy values", () => {
|
||||
expect(isTruthyEnvValue("1")).toBe(true);
|
||||
expect(isTruthyEnvValue("true")).toBe(true);
|
||||
expect(isTruthyEnvValue(" yes ")).toBe(true);
|
||||
expect(isTruthyEnvValue("ON")).toBe(true);
|
||||
});
|
||||
|
||||
it("rejects other values", () => {
|
||||
expect(isTruthyEnvValue("0")).toBe(false);
|
||||
expect(isTruthyEnvValue("false")).toBe(false);
|
||||
expect(isTruthyEnvValue("")).toBe(false);
|
||||
expect(isTruthyEnvValue(undefined)).toBe(false);
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user