From 8d2d6db9ada1dc1afe482cf7e52d4526c2cf5d6c Mon Sep 17 00:00:00 2001 From: Peter Steinberger Date: Mon, 9 Mar 2026 06:45:02 +0000 Subject: [PATCH] test: fix Node 24+ test runner and subagent registry mocks --- scripts/test-parallel.mjs | 6 +++--- src/agents/subagent-registry.archive.e2e.test.ts | 14 +++++++++----- ...gent-registry.lifecycle-retry-grace.e2e.test.ts | 10 +++++++--- src/agents/subagent-registry.nested.e2e.test.ts | 14 +++++++++----- 4 files changed, 28 insertions(+), 16 deletions(-) diff --git a/scripts/test-parallel.mjs b/scripts/test-parallel.mjs index 67129a24aea..ca7636394bb 100644 --- a/scripts/test-parallel.mjs +++ b/scripts/test-parallel.mjs @@ -104,11 +104,11 @@ const hostMemoryGiB = Math.floor(os.totalmem() / 1024 ** 3); const highMemLocalHost = !isCI && hostMemoryGiB >= 96; const lowMemLocalHost = !isCI && hostMemoryGiB < 64; const nodeMajor = Number.parseInt(process.versions.node.split(".")[0] ?? "", 10); -// vmForks is a big win for transform/import heavy suites, but Node 24 had -// regressions with Vitest's vm runtime in this repo, and low-memory local hosts +// vmForks is a big win for transform/import heavy suites, but Node 24+ +// regressed with Vitest's vm runtime in this repo, and low-memory local hosts // are more likely to hit per-worker V8 heap ceilings. Keep it opt-out via // OPENCLAW_TEST_VM_FORKS=0, and let users force-enable with =1. -const supportsVmForks = Number.isFinite(nodeMajor) ? nodeMajor !== 24 : true; +const supportsVmForks = Number.isFinite(nodeMajor) ? nodeMajor < 24 : true; const useVmForks = process.env.OPENCLAW_TEST_VM_FORKS === "1" || (process.env.OPENCLAW_TEST_VM_FORKS !== "0" && !isWindows && supportsVmForks && !lowMemLocalHost); diff --git a/src/agents/subagent-registry.archive.e2e.test.ts b/src/agents/subagent-registry.archive.e2e.test.ts index 20148db527a..8cd2a9b634e 100644 --- a/src/agents/subagent-registry.archive.e2e.test.ts +++ b/src/agents/subagent-registry.archive.e2e.test.ts @@ -17,11 +17,15 @@ vi.mock("../infra/agent-events.js", () => ({ onAgentEvent: vi.fn((_handler: unknown) => noop), })); -vi.mock("../config/config.js", () => ({ - loadConfig: vi.fn(() => ({ - agents: { defaults: { subagents: { archiveAfterMinutes: 60 } } }, - })), -})); +vi.mock("../config/config.js", async (importOriginal) => { + const actual = await importOriginal(); + return { + ...actual, + loadConfig: vi.fn(() => ({ + agents: { defaults: { subagents: { archiveAfterMinutes: 60 } } }, + })), + }; +}); vi.mock("./subagent-announce.js", () => ({ runSubagentAnnounceFlow: vi.fn(async () => true), diff --git a/src/agents/subagent-registry.lifecycle-retry-grace.e2e.test.ts b/src/agents/subagent-registry.lifecycle-retry-grace.e2e.test.ts index 9373ee5de64..570c51d3131 100644 --- a/src/agents/subagent-registry.lifecycle-retry-grace.e2e.test.ts +++ b/src/agents/subagent-registry.lifecycle-retry-grace.e2e.test.ts @@ -49,9 +49,13 @@ vi.mock("../infra/agent-events.js", () => ({ onAgentEvent: onAgentEventMock, })); -vi.mock("../config/config.js", () => ({ - loadConfig: loadConfigMock, -})); +vi.mock("../config/config.js", async (importOriginal) => { + const actual = await importOriginal(); + return { + ...actual, + loadConfig: loadConfigMock, + }; +}); vi.mock("./subagent-announce.js", () => ({ runSubagentAnnounceFlow: announceSpy, diff --git a/src/agents/subagent-registry.nested.e2e.test.ts b/src/agents/subagent-registry.nested.e2e.test.ts index 30e447149c2..06148705986 100644 --- a/src/agents/subagent-registry.nested.e2e.test.ts +++ b/src/agents/subagent-registry.nested.e2e.test.ts @@ -1,11 +1,15 @@ import { afterEach, beforeAll, describe, expect, it, vi } from "vitest"; import "./subagent-registry.mocks.shared.js"; -vi.mock("../config/config.js", () => ({ - loadConfig: vi.fn(() => ({ - agents: { defaults: { subagents: { archiveAfterMinutes: 0 } } }, - })), -})); +vi.mock("../config/config.js", async (importOriginal) => { + const actual = await importOriginal(); + return { + ...actual, + loadConfig: vi.fn(() => ({ + agents: { defaults: { subagents: { archiveAfterMinutes: 0 } } }, + })), + }; +}); vi.mock("./subagent-announce.js", () => ({ runSubagentAnnounceFlow: vi.fn(async () => true),