mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-09 13:54:30 +00:00
refactor: centralize presence routing and version precedence coverage (#19609)
Merged via /review-pr -> /prepare-pr -> /merge-pr.
Prepared head SHA: 10d9df5263
Co-authored-by: gumadeiras <5599352+gumadeiras@users.noreply.github.com>
Co-authored-by: gumadeiras <5599352+gumadeiras@users.noreply.github.com>
Reviewed-by: @gumadeiras
This commit is contained in:
committed by
GitHub
parent
5c69e625f5
commit
07fdceb5fd
60
src/infra/system-presence.version.test.ts
Normal file
60
src/infra/system-presence.version.test.ts
Normal file
@@ -0,0 +1,60 @@
|
||||
import { describe, expect, it, vi } from "vitest";
|
||||
import { withEnvAsync } from "../test-utils/env.js";
|
||||
|
||||
async function withPresenceModule<T>(
|
||||
env: Record<string, string | undefined>,
|
||||
run: (module: typeof import("./system-presence.js")) => Promise<T> | T,
|
||||
): Promise<T> {
|
||||
return withEnvAsync(env, async () => {
|
||||
vi.resetModules();
|
||||
try {
|
||||
const module = await import("./system-presence.js");
|
||||
return await run(module);
|
||||
} finally {
|
||||
vi.resetModules();
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
describe("system-presence version fallback", () => {
|
||||
it("uses OPENCLAW_SERVICE_VERSION when OPENCLAW_VERSION is not set", async () => {
|
||||
await withPresenceModule(
|
||||
{
|
||||
OPENCLAW_SERVICE_VERSION: "2.4.6-service",
|
||||
npm_package_version: "1.0.0-package",
|
||||
},
|
||||
({ listSystemPresence }) => {
|
||||
const selfEntry = listSystemPresence().find((entry) => entry.reason === "self");
|
||||
expect(selfEntry?.version).toBe("2.4.6-service");
|
||||
},
|
||||
);
|
||||
});
|
||||
|
||||
it("prefers OPENCLAW_VERSION over OPENCLAW_SERVICE_VERSION", async () => {
|
||||
await withPresenceModule(
|
||||
{
|
||||
OPENCLAW_VERSION: "9.9.9-cli",
|
||||
OPENCLAW_SERVICE_VERSION: "2.4.6-service",
|
||||
npm_package_version: "1.0.0-package",
|
||||
},
|
||||
({ listSystemPresence }) => {
|
||||
const selfEntry = listSystemPresence().find((entry) => entry.reason === "self");
|
||||
expect(selfEntry?.version).toBe("9.9.9-cli");
|
||||
},
|
||||
);
|
||||
});
|
||||
|
||||
it("uses npm_package_version when OPENCLAW_VERSION and OPENCLAW_SERVICE_VERSION are blank", async () => {
|
||||
await withPresenceModule(
|
||||
{
|
||||
OPENCLAW_VERSION: " ",
|
||||
OPENCLAW_SERVICE_VERSION: "\t",
|
||||
npm_package_version: "1.0.0-package",
|
||||
},
|
||||
({ listSystemPresence }) => {
|
||||
const selfEntry = listSystemPresence().find((entry) => entry.reason === "self");
|
||||
expect(selfEntry?.version).toBe("1.0.0-package");
|
||||
},
|
||||
);
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user