mirror of
https://github.com/openclaw/openclaw.git
synced 2026-03-12 23:40: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
68 lines
2.0 KiB
TypeScript
68 lines
2.0 KiB
TypeScript
import { describe, expect, it } from "vitest";
|
|
import { BlueBubblesConfigSchema } from "./config-schema.js";
|
|
|
|
describe("BlueBubblesConfigSchema", () => {
|
|
it("accepts account config when serverUrl and password are both set", () => {
|
|
const parsed = BlueBubblesConfigSchema.safeParse({
|
|
serverUrl: "http://localhost:1234",
|
|
password: "secret", // pragma: allowlist secret
|
|
});
|
|
expect(parsed.success).toBe(true);
|
|
});
|
|
|
|
it("accepts SecretRef password when serverUrl is set", () => {
|
|
const parsed = BlueBubblesConfigSchema.safeParse({
|
|
serverUrl: "http://localhost:1234",
|
|
password: {
|
|
source: "env",
|
|
provider: "default",
|
|
id: "BLUEBUBBLES_PASSWORD",
|
|
},
|
|
});
|
|
expect(parsed.success).toBe(true);
|
|
});
|
|
|
|
it("requires password when top-level serverUrl is configured", () => {
|
|
const parsed = BlueBubblesConfigSchema.safeParse({
|
|
serverUrl: "http://localhost:1234",
|
|
});
|
|
expect(parsed.success).toBe(false);
|
|
if (parsed.success) {
|
|
return;
|
|
}
|
|
expect(parsed.error.issues[0]?.path).toEqual(["password"]);
|
|
expect(parsed.error.issues[0]?.message).toBe(
|
|
"password is required when serverUrl is configured",
|
|
);
|
|
});
|
|
|
|
it("requires password when account serverUrl is configured", () => {
|
|
const parsed = BlueBubblesConfigSchema.safeParse({
|
|
accounts: {
|
|
work: {
|
|
serverUrl: "http://localhost:1234",
|
|
},
|
|
},
|
|
});
|
|
expect(parsed.success).toBe(false);
|
|
if (parsed.success) {
|
|
return;
|
|
}
|
|
expect(parsed.error.issues[0]?.path).toEqual(["accounts", "work", "password"]);
|
|
expect(parsed.error.issues[0]?.message).toBe(
|
|
"password is required when serverUrl is configured",
|
|
);
|
|
});
|
|
|
|
it("allows password omission when serverUrl is not configured", () => {
|
|
const parsed = BlueBubblesConfigSchema.safeParse({
|
|
accounts: {
|
|
work: {
|
|
name: "Work iMessage",
|
|
},
|
|
},
|
|
});
|
|
expect(parsed.success).toBe(true);
|
|
});
|
|
});
|