mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-06 20:00:42 +00:00
test: add normalization coverage for shared and slack allow-list
This commit is contained in:
25
src/shared/string-normalization.test.ts
Normal file
25
src/shared/string-normalization.test.ts
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
import { describe, expect, it } from "vitest";
|
||||||
|
import {
|
||||||
|
normalizeHyphenSlug,
|
||||||
|
normalizeStringEntries,
|
||||||
|
normalizeStringEntriesLower,
|
||||||
|
} from "./string-normalization.js";
|
||||||
|
|
||||||
|
describe("shared/string-normalization", () => {
|
||||||
|
it("normalizes mixed allow-list entries", () => {
|
||||||
|
expect(normalizeStringEntries([" a ", 42, "", " ", "z"])).toEqual(["a", "42", "z"]);
|
||||||
|
expect(normalizeStringEntries(undefined)).toEqual([]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("normalizes mixed allow-list entries to lowercase", () => {
|
||||||
|
expect(normalizeStringEntriesLower([" A ", "MiXeD", 7])).toEqual(["a", "mixed", "7"]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("normalizes slug-like labels while preserving supported symbols", () => {
|
||||||
|
expect(normalizeHyphenSlug(" Team Room ")).toBe("team-room");
|
||||||
|
expect(normalizeHyphenSlug(" #My_Channel + Alerts ")).toBe("#my_channel-+-alerts");
|
||||||
|
expect(normalizeHyphenSlug("..foo---bar..")).toBe("foo-bar");
|
||||||
|
expect(normalizeHyphenSlug(undefined)).toBe("");
|
||||||
|
expect(normalizeHyphenSlug(null)).toBe("");
|
||||||
|
});
|
||||||
|
});
|
||||||
56
src/slack/monitor/allow-list.test.ts
Normal file
56
src/slack/monitor/allow-list.test.ts
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
import { describe, expect, it } from "vitest";
|
||||||
|
import {
|
||||||
|
normalizeAllowList,
|
||||||
|
normalizeAllowListLower,
|
||||||
|
normalizeSlackSlug,
|
||||||
|
resolveSlackAllowListMatch,
|
||||||
|
resolveSlackUserAllowed,
|
||||||
|
} from "./allow-list.js";
|
||||||
|
|
||||||
|
describe("slack/allow-list", () => {
|
||||||
|
it("normalizes lists and slugs", () => {
|
||||||
|
expect(normalizeAllowList([" Alice ", 7, "", " "])).toEqual(["Alice", "7"]);
|
||||||
|
expect(normalizeAllowListLower([" Alice ", 7])).toEqual(["alice", "7"]);
|
||||||
|
expect(normalizeSlackSlug(" Team Space ")).toBe("team-space");
|
||||||
|
expect(normalizeSlackSlug(" #Ops.Room ")).toBe("#ops.room");
|
||||||
|
});
|
||||||
|
|
||||||
|
it("matches wildcard, id, and prefixed name candidates", () => {
|
||||||
|
expect(resolveSlackAllowListMatch({ allowList: ["*"], id: "u1", name: "alice" })).toEqual({
|
||||||
|
allowed: true,
|
||||||
|
matchKey: "*",
|
||||||
|
matchSource: "wildcard",
|
||||||
|
});
|
||||||
|
|
||||||
|
expect(
|
||||||
|
resolveSlackAllowListMatch({
|
||||||
|
allowList: ["u1"],
|
||||||
|
id: "u1",
|
||||||
|
name: "alice",
|
||||||
|
}),
|
||||||
|
).toEqual({
|
||||||
|
allowed: true,
|
||||||
|
matchKey: "u1",
|
||||||
|
matchSource: "id",
|
||||||
|
});
|
||||||
|
|
||||||
|
expect(
|
||||||
|
resolveSlackAllowListMatch({
|
||||||
|
allowList: ["slack:alice"],
|
||||||
|
id: "u2",
|
||||||
|
name: "alice",
|
||||||
|
}),
|
||||||
|
).toEqual({
|
||||||
|
allowed: true,
|
||||||
|
matchKey: "slack:alice",
|
||||||
|
matchSource: "prefixed-name",
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("allows all users when allowList is empty and denies unknown entries", () => {
|
||||||
|
expect(resolveSlackUserAllowed({ allowList: [], userId: "u1", userName: "alice" })).toBe(true);
|
||||||
|
expect(resolveSlackUserAllowed({ allowList: ["u2"], userId: "u1", userName: "alice" })).toBe(
|
||||||
|
false,
|
||||||
|
);
|
||||||
|
});
|
||||||
|
});
|
||||||
Reference in New Issue
Block a user