mirror of
http://192.168.0.88:13333/lywsvip/openclaw-zero-token.git
synced 2026-05-31 14:12:38 +08:00
Major upgrade from e26988a38 to upstream v2026.3.28 (f9b107928).
Key changes:
- Upstream src/, ui/, extensions/ (89 bundled extensions)
- Zero-token web providers preserved in src/zero-token/
- AskOnce plugin restored and registered as CLI command
- Added missing packages: @anthropic-ai/vertex-sdk, @modelcontextprotocol/sdk
- Fixed tsconfig rootDir, skipLibCheck for plugin-sdk DTS build
- Added askonce to bundled plugin metadata and package.json exports
- Fixed AskOnce CLI command registration (missing commands metadata)
- Restored AskOnce adapter imports (correct 5-level relative paths)
- Removed stale migration artifacts from root directory
43 lines
1.4 KiB
TypeScript
43 lines
1.4 KiB
TypeScript
import { describe, expect, it, vi } from "vitest";
|
|
import { createRunStateMachine } from "./run-state-machine.js";
|
|
|
|
describe("createRunStateMachine", () => {
|
|
it("resets stale busy fields on init", () => {
|
|
const setStatus = vi.fn();
|
|
createRunStateMachine({ setStatus });
|
|
expect(setStatus).toHaveBeenCalledWith({ activeRuns: 0, busy: false });
|
|
});
|
|
|
|
it("emits busy status while active and clears when done", () => {
|
|
const setStatus = vi.fn();
|
|
const machine = createRunStateMachine({
|
|
setStatus,
|
|
now: () => 123,
|
|
});
|
|
machine.onRunStart();
|
|
machine.onRunEnd();
|
|
expect(setStatus).toHaveBeenNthCalledWith(
|
|
2,
|
|
expect.objectContaining({ activeRuns: 1, busy: true, lastRunActivityAt: 123 }),
|
|
);
|
|
expect(setStatus).toHaveBeenLastCalledWith(
|
|
expect.objectContaining({ activeRuns: 0, busy: false, lastRunActivityAt: 123 }),
|
|
);
|
|
});
|
|
|
|
it("stops publishing after lifecycle abort", () => {
|
|
const setStatus = vi.fn();
|
|
const abortController = new AbortController();
|
|
const machine = createRunStateMachine({
|
|
setStatus,
|
|
abortSignal: abortController.signal,
|
|
now: () => 999,
|
|
});
|
|
machine.onRunStart();
|
|
const callsBeforeAbort = setStatus.mock.calls.length;
|
|
abortController.abort();
|
|
machine.onRunEnd();
|
|
expect(setStatus.mock.calls.length).toBe(callsBeforeAbort);
|
|
});
|
|
});
|