mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-06 08:20:43 +00:00
* fix(scripts): find codex protocol source from worktrees * fix(test): keep codex harness docker caches writable * fix(test): relax live codex cache mount permissions * test(codex): add live docker harness debug output * fix(test): detect numeric ci env in codex docker harness * fix(codex): skip duplicate agent-command telemetry * fix(tooling): skip sparse-missing oxlint tsconfig * fix(tooling): route changed checks through testbox * fix(qa): keep coverage json source-clean * fix(test): preflight codex docker auth * fix(codex): validate bind option values * fix(codex): parse quoted command arguments * fix(codex): reject extra control args * fix(codex): use content for blank bound prompts * fix(codex): decode local image file urls * fix(codex): treat local media urls as images * fix(codex): keep windows media paths local * fix(codex): reject malformed diagnostics confirmations * fix(codex): reject malformed resume commands * fix(codex): reject malformed thread actions * fix(codex): reject malformed turn controls * fix(codex): reject malformed model controls * fix(codex): resolve empty user input prompts * fix(codex): enforce user input options * fix(codex): reject ambiguous computer-use actions * fix(codex): ignore stale bound turn notifications * test(gateway): close task registries in gateway harness * test(gateway): route cleanup through task seams * fix(codex): describe current permission approvals * fix(codex): disclose command approval amendments * fix(codex): preserve approval detail under truncation * fix(codex): propagate dynamic tool failures * test(codex): align dynamic tool block contract * fix(codex): reject extra read-only command operands * fix(codex): escape command readout fields * fix(codex): escape status probe errors * fix(codex): narrow formatted thread details * fix(codex): escape successful status summaries * fix(codex): escape bound control replies * fix(codex): escape user input prompts * fix(codex): escape control failure replies * fix(codex): escape approval prompt text * test(codex): narrow escaped reply assertions * test(codex): complete strict reply fixtures * test(codex): preserve account fixture literals * test(codex): align status probe fixtures * fix(codex): satisfy sanitizer regex lint * fix(codex): harden command readouts * fix(codex): harden bound image inputs * fix(codex): sanitize command failure replies * test(codex): complete rate limit fixture * test(tooling): isolate postinstall compile cache fixture * fix(codex): keep app-server event ownership explicit --------- Co-authored-by: pashpashpash <nik@vault77.ai>
59 lines
2.2 KiB
TypeScript
59 lines
2.2 KiB
TypeScript
import fs from "node:fs";
|
|
import path from "node:path";
|
|
import { afterEach, describe, expect, it } from "vitest";
|
|
import { resolveCodexAppServerProtocolSource } from "../../scripts/lib/codex-app-server-protocol-source.js";
|
|
import { createScriptTestHarness } from "./test-helpers.js";
|
|
|
|
const { createTempDir } = createScriptTestHarness();
|
|
const originalOpenClawCodexRepo = process.env.OPENCLAW_CODEX_REPO;
|
|
|
|
afterEach(() => {
|
|
if (originalOpenClawCodexRepo === undefined) {
|
|
delete process.env.OPENCLAW_CODEX_REPO;
|
|
} else {
|
|
process.env.OPENCLAW_CODEX_REPO = originalOpenClawCodexRepo;
|
|
}
|
|
});
|
|
|
|
describe("codex app-server protocol source resolver", () => {
|
|
it("uses OPENCLAW_CODEX_REPO when provided", async () => {
|
|
const root = createTempDir("openclaw-protocol-source-root-");
|
|
const codexRepo = createTempDir("openclaw-protocol-source-codex-");
|
|
createProtocolSchema(codexRepo);
|
|
process.env.OPENCLAW_CODEX_REPO = codexRepo;
|
|
|
|
await expect(resolveCodexAppServerProtocolSource(root)).resolves.toEqual({
|
|
codexRepo,
|
|
sourceRoot: path.join(codexRepo, "codex-rs/app-server-protocol/schema"),
|
|
});
|
|
});
|
|
|
|
it("finds the primary checkout sibling from a git worktree", async () => {
|
|
const parentDir = createTempDir("openclaw-protocol-source-parent-");
|
|
const primaryOpenClaw = path.join(parentDir, "openclaw");
|
|
const codexRepo = path.join(parentDir, "codex");
|
|
const worktreeRoot = createTempDir("openclaw-protocol-source-worktree-");
|
|
fs.mkdirSync(path.join(primaryOpenClaw, ".git", "worktrees", "codex-harness"), {
|
|
recursive: true,
|
|
});
|
|
fs.mkdirSync(worktreeRoot, { recursive: true });
|
|
fs.writeFileSync(
|
|
path.join(worktreeRoot, ".git"),
|
|
`gitdir: ${path.join(primaryOpenClaw, ".git", "worktrees", "codex-harness")}\n`,
|
|
);
|
|
createProtocolSchema(codexRepo);
|
|
delete process.env.OPENCLAW_CODEX_REPO;
|
|
|
|
await expect(resolveCodexAppServerProtocolSource(worktreeRoot)).resolves.toMatchObject({
|
|
codexRepo,
|
|
sourceRoot: path.join(codexRepo, "codex-rs/app-server-protocol/schema"),
|
|
});
|
|
});
|
|
});
|
|
|
|
function createProtocolSchema(codexRepo: string): void {
|
|
fs.mkdirSync(path.join(codexRepo, "codex-rs/app-server-protocol/schema/typescript"), {
|
|
recursive: true,
|
|
});
|
|
}
|