Files
claude-code/src/utils/__tests__/envValidation.test.ts
claude-code-best 1a910ed639 refactor: 统一 log.ts/debug.ts 的测试 mock 为共享定义
- 新增 tests/mocks/log.ts 和 tests/mocks/debug.ts,覆盖源文件全部实际导出
- 移除旧 mock 中不存在的导出(logToFile、logEvent、getLogFilePath)
- 13 个测试文件改为使用共享 mock,避免定义分散和不一致

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-04-22 23:35:59 +08:00

95 lines
3.6 KiB
TypeScript

import { mock, describe, expect, test } from "bun:test";
import { debugMock } from "../../../tests/mocks/debug";
// Mock debug.ts to cut bootstrap/state dependency chain
mock.module("src/utils/debug.ts", debugMock);
const { validateBoundedIntEnvVar } = await import("../envValidation");
describe("validateBoundedIntEnvVar", () => {
test("returns default when value is undefined", () => {
const result = validateBoundedIntEnvVar("TEST_VAR", undefined, 100, 1000);
expect(result).toEqual({ effective: 100, status: "valid" });
});
test("returns default when value is empty string", () => {
const result = validateBoundedIntEnvVar("TEST_VAR", "", 100, 1000);
expect(result).toEqual({ effective: 100, status: "valid" });
});
test("returns parsed value when valid and within limit", () => {
const result = validateBoundedIntEnvVar("TEST_VAR", "500", 100, 1000);
expect(result).toEqual({ effective: 500, status: "valid" });
});
test("caps value at upper limit", () => {
const result = validateBoundedIntEnvVar("TEST_VAR", "2000", 100, 1000);
expect(result.effective).toBe(1000);
expect(result.status).toBe("capped");
expect(result.message).toBe("Capped from 2000 to 1000");
});
test("returns default for non-numeric value", () => {
const result = validateBoundedIntEnvVar("TEST_VAR", "abc", 100, 1000);
expect(result.effective).toBe(100);
expect(result.status).toBe("invalid");
expect(result.message).toBe('Invalid value "abc" (using default: 100)');
});
test("returns default for zero", () => {
const result = validateBoundedIntEnvVar("TEST_VAR", "0", 100, 1000);
expect(result.effective).toBe(100);
expect(result.status).toBe("invalid");
});
test("returns default for negative value", () => {
const result = validateBoundedIntEnvVar("TEST_VAR", "-5", 100, 1000);
expect(result.effective).toBe(100);
expect(result.status).toBe("invalid");
});
test("handles value at exact upper limit", () => {
const result = validateBoundedIntEnvVar("TEST_VAR", "1000", 100, 1000);
expect(result.effective).toBe(1000);
expect(result.status).toBe("valid");
});
test("handles value of 1 (no lower bound check, only parsed > 0)", () => {
const result = validateBoundedIntEnvVar("TEST_VAR", "1", 100, 1000);
expect(result.effective).toBe(1);
expect(result.status).toBe("valid");
});
test("truncates float input via parseInt", () => {
const result = validateBoundedIntEnvVar("TEST_VAR", "50.7", 100, 1000);
expect(result.effective).toBe(50);
expect(result.status).toBe("valid");
});
test("handles whitespace in value", () => {
const result = validateBoundedIntEnvVar("TEST_VAR", " 500 ", 100, 1000);
expect(result.effective).toBe(500);
expect(result.status).toBe("valid");
});
test("value=1 with high defaultValue returns 1 (no lower bound enforcement)", () => {
// Function only checks parsed > 0 and parsed <= upperLimit
// It does NOT enforce that parsed >= defaultValue
const result = validateBoundedIntEnvVar("TEST_VAR", "1", 100, 1000);
expect(result.effective).toBe(1);
expect(result.status).toBe("valid");
});
test("caps very large number at upper limit", () => {
const result = validateBoundedIntEnvVar("TEST_VAR", "999999999", 100, 1000);
expect(result.effective).toBe(1000);
expect(result.status).toBe("capped");
});
test("treats NaN-producing strings as invalid", () => {
const result = validateBoundedIntEnvVar("TEST_VAR", "NaN", 100, 1000);
expect(result.effective).toBe(100);
expect(result.status).toBe("invalid");
});
});