mirror of
https://github.com/openclaw/openclaw.git
synced 2026-03-12 07:20:45 +00:00
* Secrets: add inline allowlist review set * Secrets: narrow detect-secrets file exclusions * Secrets: exclude Docker fingerprint false positive * Secrets: allowlist test and docs false positives * Secrets: refresh baseline after allowlist updates * Secrets: fix gateway chat fixture pragma * Secrets: format pre-commit config * Android: keep talk mode fixture JSON valid * Feishu: rely on client timeout injection * Secrets: allowlist provider auth test fixtures * Secrets: allowlist onboard search fixtures * Secrets: allowlist onboard mode fixture * Secrets: allowlist gateway auth mode fixture * Secrets: allowlist APNS wake test key * Secrets: allowlist gateway reload fixtures * Secrets: allowlist moonshot video fixture * Secrets: allowlist auto audio fixture * Secrets: allowlist tiny audio fixture * Secrets: allowlist embeddings fixtures * Secrets: allowlist resolve fixtures * Secrets: allowlist target registry pattern fixtures * Secrets: allowlist gateway chat env fixture * Secrets: refresh baseline after fixture allowlists * Secrets: reapply gateway chat env allowlist * Secrets: reapply gateway chat env allowlist * Secrets: stabilize gateway chat env allowlist * Secrets: allowlist runtime snapshot save fixture * Secrets: allowlist oauth profile fixtures * Secrets: allowlist compaction identifier fixture * Secrets: allowlist model auth fixture * Secrets: allowlist model status fixtures * Secrets: allowlist custom onboarding fixture * Secrets: allowlist mattermost token summary fixtures * Secrets: allowlist gateway auth suite fixtures * Secrets: allowlist channel summary fixture * Secrets: allowlist provider usage auth fixtures * Secrets: allowlist media proxy fixture * Secrets: allowlist secrets audit fixtures * Secrets: refresh baseline after final fixture allowlists * Feishu: prefer explicit client timeout * Feishu: test direct timeout precedence
73 lines
2.5 KiB
TypeScript
73 lines
2.5 KiB
TypeScript
import { describe, expect, it } from "vitest";
|
|
import {
|
|
createRequestCaptureJsonFetch,
|
|
installPinnedHostnameTestHooks,
|
|
} from "../audio.test-helpers.js";
|
|
import { describeMoonshotVideo } from "./video.js";
|
|
|
|
installPinnedHostnameTestHooks();
|
|
|
|
describe("describeMoonshotVideo", () => {
|
|
it("builds an OpenAI-compatible video request", async () => {
|
|
const { fetchFn, getRequest } = createRequestCaptureJsonFetch({
|
|
choices: [{ message: { content: "video ok" } }],
|
|
});
|
|
|
|
const result = await describeMoonshotVideo({
|
|
buffer: Buffer.from("video-bytes"),
|
|
fileName: "clip.mp4",
|
|
apiKey: "moonshot-test", // pragma: allowlist secret
|
|
timeoutMs: 1500,
|
|
baseUrl: "https://api.moonshot.ai/v1/",
|
|
model: "kimi-k2.5",
|
|
headers: { "X-Trace": "1" },
|
|
fetchFn,
|
|
});
|
|
const { url, init } = getRequest();
|
|
|
|
expect(result.text).toBe("video ok");
|
|
expect(result.model).toBe("kimi-k2.5");
|
|
expect(url).toBe("https://api.moonshot.ai/v1/chat/completions");
|
|
expect(init?.method).toBe("POST");
|
|
expect(init?.signal).toBeInstanceOf(AbortSignal);
|
|
|
|
const headers = new Headers(init?.headers);
|
|
expect(headers.get("authorization")).toBe("Bearer moonshot-test");
|
|
expect(headers.get("content-type")).toBe("application/json");
|
|
expect(headers.get("x-trace")).toBe("1");
|
|
|
|
const body = JSON.parse(typeof init?.body === "string" ? init.body : "{}") as {
|
|
model?: string;
|
|
messages?: Array<{
|
|
content?: Array<{ type?: string; text?: string; video_url?: { url?: string } }>;
|
|
}>;
|
|
};
|
|
expect(body.model).toBe("kimi-k2.5");
|
|
expect(body.messages?.[0]?.content?.[0]).toMatchObject({
|
|
type: "text",
|
|
text: "Describe the video.",
|
|
});
|
|
expect(body.messages?.[0]?.content?.[1]?.type).toBe("video_url");
|
|
expect(body.messages?.[0]?.content?.[1]?.video_url?.url).toBe(
|
|
`data:video/mp4;base64,${Buffer.from("video-bytes").toString("base64")}`,
|
|
);
|
|
});
|
|
|
|
it("falls back to reasoning_content when content is empty", async () => {
|
|
const { fetchFn } = createRequestCaptureJsonFetch({
|
|
choices: [{ message: { content: "", reasoning_content: "reasoned answer" } }],
|
|
});
|
|
|
|
const result = await describeMoonshotVideo({
|
|
buffer: Buffer.from("video"),
|
|
fileName: "clip.mp4",
|
|
apiKey: "moonshot-test", // pragma: allowlist secret
|
|
timeoutMs: 1000,
|
|
fetchFn,
|
|
});
|
|
|
|
expect(result.text).toBe("reasoned answer");
|
|
expect(result.model).toBe("kimi-k2.5");
|
|
});
|
|
});
|