test(heartbeat): use shared sandbox in sender target suite

This commit is contained in:
Peter Steinberger
2026-02-22 09:29:34 +00:00
parent 29e41d4c0a
commit c8d473c8e8

View File

@@ -1,13 +1,8 @@
import fs from "node:fs/promises";
import os from "node:os";
import path from "node:path";
import { describe, expect, it, vi } from "vitest";
import * as replyModule from "../auto-reply/reply.js";
import type { OpenClawConfig } from "../config/config.js";
import { resolveMainSessionKey } from "../config/sessions.js";
import { runHeartbeatOnce } from "./heartbeat-runner.js";
import { installHeartbeatRunnerTestRuntime } from "./heartbeat-runner.test-harness.js";
import { seedSessionStore } from "./heartbeat-runner.test-utils.js";
import { seedMainSessionStore, withTempHeartbeatSandbox } from "./heartbeat-runner.test-utils.js";
// Avoid pulling optional runtime deps during isolated runs.
vi.mock("jiti", () => ({ createJiti: () => () => ({}) }));
@@ -16,11 +11,8 @@ installHeartbeatRunnerTestRuntime({ includeSlack: true });
describe("runHeartbeatOnce", () => {
it("uses the delivery target as sender when lastTo differs", async () => {
const tmpDir = await fs.mkdtemp(path.join(os.tmpdir(), "openclaw-hb-"));
await fs.writeFile(path.join(tmpDir, "HEARTBEAT.md"), "- Check status\n", "utf-8");
const storePath = path.join(tmpDir, "sessions.json");
const replySpy = vi.spyOn(replyModule, "getReplyFromConfig");
try {
await withTempHeartbeatSandbox(
async ({ tmpDir, storePath, replySpy }) => {
const cfg: OpenClawConfig = {
agents: {
defaults: {
@@ -34,15 +26,14 @@ describe("runHeartbeatOnce", () => {
},
session: { store: storePath },
};
const sessionKey = resolveMainSessionKey(cfg);
await seedSessionStore(storePath, sessionKey, {
await seedMainSessionStore(storePath, cfg, {
lastChannel: "telegram",
lastProvider: "telegram",
lastTo: "1644620762",
});
replySpy.mockImplementation(async (ctx) => {
replySpy.mockImplementation(async (ctx: { To?: string; From?: string }) => {
expect(ctx.To).toBe("C0A9P2N8QHY");
expect(ctx.From).toBe("C0A9P2N8QHY");
return { text: "ok" };
@@ -63,9 +54,8 @@ describe("runHeartbeatOnce", () => {
});
expect(sendSlack).toHaveBeenCalled();
} finally {
replySpy.mockRestore();
await fs.rm(tmpDir, { recursive: true, force: true });
}
},
{ prefix: "openclaw-hb-" },
);
});
});