mirror of
https://github.com/openclaw/openclaw.git
synced 2026-04-28 20:46:57 +02:00
142 lines
4.0 KiB
TypeScript
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,
|
|
});
|
|
});
|
|
});
|