Files
openclaw/test/scripts/vitest-local-scheduling.test.ts
2026-04-25 03:07:27 -07:00

142 lines
4.0 KiB
TypeScript

import { describe, expect, it } from "vitest";
import {
resolveLocalVitestEnv,
resolveLocalFullSuiteProfile,
resolveLocalVitestScheduling,
shouldUseLargeLocalFullSuiteProfile,
} from "../../scripts/lib/vitest-local-scheduling.mjs";
describe("vitest local full-suite profile", () => {
it("forces local Vitest runs back onto local-check policy", () => {
expect(resolveLocalVitestEnv({ OPENCLAW_LOCAL_CHECK: "0", PATH: "/usr/bin" })).toEqual({
OPENCLAW_LOCAL_CHECK: "1",
PATH: "/usr/bin",
});
expect(resolveLocalVitestEnv({ OPENCLAW_LOCAL_CHECK: "false", PATH: "/usr/bin" })).toEqual({
OPENCLAW_LOCAL_CHECK: "1",
PATH: "/usr/bin",
});
});
it("keeps local-check disablement for CI Vitest runs", () => {
expect(
resolveLocalVitestEnv({
CI: "true",
OPENCLAW_LOCAL_CHECK: "0",
PATH: "/usr/bin",
}),
).toEqual({
CI: "true",
OPENCLAW_LOCAL_CHECK: "0",
PATH: "/usr/bin",
});
});
it("selects the large local profile on roomy hosts that are not throttled", () => {
const env = {};
const hostInfo = {
cpuCount: 14,
loadAverage1m: 0,
totalMemoryBytes: 48 * 1024 ** 3,
};
expect(resolveLocalVitestScheduling(env, hostInfo, "threads")).toEqual({
maxWorkers: 6,
fileParallelism: true,
throttledBySystem: false,
});
expect(shouldUseLargeLocalFullSuiteProfile(env, hostInfo)).toBe(true);
expect(resolveLocalFullSuiteProfile(env, hostInfo)).toEqual({
shardParallelism: 10,
vitestMaxWorkers: 2,
});
});
it("keeps the smaller local profile when the host is already throttled", () => {
const hostInfo = {
cpuCount: 14,
loadAverage1m: 14,
totalMemoryBytes: 48 * 1024 ** 3,
freeMemoryBytes: 32 * 1024 ** 3,
};
expect(shouldUseLargeLocalFullSuiteProfile({}, hostInfo)).toBe(false);
expect(resolveLocalFullSuiteProfile({}, hostInfo)).toEqual({
shardParallelism: 4,
vitestMaxWorkers: 1,
});
});
it("never selects the large local profile in CI", () => {
const hostInfo = {
cpuCount: 14,
loadAverage1m: 0,
totalMemoryBytes: 48 * 1024 ** 3,
};
expect(shouldUseLargeLocalFullSuiteProfile({ CI: "true" }, hostInfo)).toBe(false);
expect(resolveLocalFullSuiteProfile({ CI: "true" }, hostInfo)).toEqual({
shardParallelism: 4,
vitestMaxWorkers: 1,
});
});
it("serializes local full-suite shards under critical memory pressure", () => {
const hostInfo = {
cpuCount: 10,
loadAverage1m: 0,
totalMemoryBytes: 24 * 1024 ** 3,
freeMemoryBytes: 3 * 1024 ** 3,
};
expect(resolveLocalVitestScheduling({}, hostInfo, "threads")).toEqual({
maxWorkers: 1,
fileParallelism: false,
throttledBySystem: true,
});
expect(resolveLocalFullSuiteProfile({}, hostInfo)).toEqual({
shardParallelism: 1,
vitestMaxWorkers: 1,
});
});
it("limits local full-suite shards when memory is tight", () => {
const hostInfo = {
cpuCount: 10,
loadAverage1m: 0,
totalMemoryBytes: 24 * 1024 ** 3,
freeMemoryBytes: 6 * 1024 ** 3,
};
expect(resolveLocalVitestScheduling({}, hostInfo, "threads")).toEqual({
maxWorkers: 2,
fileParallelism: true,
throttledBySystem: true,
});
expect(resolveLocalFullSuiteProfile({}, hostInfo)).toEqual({
shardParallelism: 2,
vitestMaxWorkers: 1,
});
});
it("lets explicit system throttle opt-out ignore memory pressure", () => {
const env = { OPENCLAW_VITEST_DISABLE_SYSTEM_THROTTLE: "1" };
const hostInfo = {
cpuCount: 10,
loadAverage1m: 0,
totalMemoryBytes: 24 * 1024 ** 3,
freeMemoryBytes: 3 * 1024 ** 3,
};
expect(resolveLocalVitestScheduling(env, hostInfo, "threads")).toEqual({
maxWorkers: 4,
fileParallelism: true,
throttledBySystem: false,
});
expect(resolveLocalFullSuiteProfile(env, hostInfo)).toEqual({
shardParallelism: 4,
vitestMaxWorkers: 1,
});
});
});