File size: 3,771 Bytes
fc93158 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 | import { describe, expect, it } from "vitest";
import {
buildSlackSlashCommandMatcher,
isSlackChannelAllowedByPolicy,
resolveSlackThreadTs,
} from "./monitor.js";
describe("slack groupPolicy gating", () => {
it("allows when policy is open", () => {
expect(
isSlackChannelAllowedByPolicy({
groupPolicy: "open",
channelAllowlistConfigured: false,
channelAllowed: false,
}),
).toBe(true);
});
it("blocks when policy is disabled", () => {
expect(
isSlackChannelAllowedByPolicy({
groupPolicy: "disabled",
channelAllowlistConfigured: true,
channelAllowed: true,
}),
).toBe(false);
});
it("blocks allowlist when no channel allowlist configured", () => {
expect(
isSlackChannelAllowedByPolicy({
groupPolicy: "allowlist",
channelAllowlistConfigured: false,
channelAllowed: true,
}),
).toBe(false);
});
it("allows allowlist when channel is allowed", () => {
expect(
isSlackChannelAllowedByPolicy({
groupPolicy: "allowlist",
channelAllowlistConfigured: true,
channelAllowed: true,
}),
).toBe(true);
});
it("blocks allowlist when channel is not allowed", () => {
expect(
isSlackChannelAllowedByPolicy({
groupPolicy: "allowlist",
channelAllowlistConfigured: true,
channelAllowed: false,
}),
).toBe(false);
});
});
describe("resolveSlackThreadTs", () => {
const threadTs = "1234567890.123456";
const messageTs = "9999999999.999999";
it("stays in incoming threads for all replyToMode values", () => {
for (const replyToMode of ["off", "first", "all"] as const) {
for (const hasReplied of [false, true]) {
expect(
resolveSlackThreadTs({
replyToMode,
incomingThreadTs: threadTs,
messageTs,
hasReplied,
}),
).toBe(threadTs);
}
}
});
describe("replyToMode=off", () => {
it("returns undefined when not in a thread", () => {
expect(
resolveSlackThreadTs({
replyToMode: "off",
incomingThreadTs: undefined,
messageTs,
hasReplied: false,
}),
).toBeUndefined();
});
});
describe("replyToMode=first", () => {
it("returns messageTs for first reply when not in a thread", () => {
expect(
resolveSlackThreadTs({
replyToMode: "first",
incomingThreadTs: undefined,
messageTs,
hasReplied: false,
}),
).toBe(messageTs);
});
it("returns undefined for subsequent replies when not in a thread (goes to main channel)", () => {
expect(
resolveSlackThreadTs({
replyToMode: "first",
incomingThreadTs: undefined,
messageTs,
hasReplied: true,
}),
).toBeUndefined();
});
});
describe("replyToMode=all", () => {
it("returns messageTs when not in a thread (starts thread)", () => {
expect(
resolveSlackThreadTs({
replyToMode: "all",
incomingThreadTs: undefined,
messageTs,
hasReplied: true,
}),
).toBe(messageTs);
});
});
});
describe("buildSlackSlashCommandMatcher", () => {
it("matches with or without a leading slash", () => {
const matcher = buildSlackSlashCommandMatcher("openclaw");
expect(matcher.test("openclaw")).toBe(true);
expect(matcher.test("/openclaw")).toBe(true);
});
it("does not match similar names", () => {
const matcher = buildSlackSlashCommandMatcher("openclaw");
expect(matcher.test("/openclaw-bot")).toBe(false);
expect(matcher.test("openclaw-bot")).toBe(false);
});
});
|