mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-25 18:03:32 +00:00
refactor: dedupe channel and gateway surfaces
This commit is contained in:
@@ -2,6 +2,22 @@ import { describe, expect, it } from "vitest";
|
||||
import { resolveSlackThreadContext, resolveSlackThreadTargets } from "./threading.js";
|
||||
|
||||
describe("resolveSlackThreadTargets", () => {
|
||||
function expectAutoCreatedTopLevelThreadTsBehavior(replyToMode: "off" | "first") {
|
||||
const { replyThreadTs, statusThreadTs, isThreadReply } = resolveSlackThreadTargets({
|
||||
replyToMode,
|
||||
message: {
|
||||
type: "message",
|
||||
channel: "C1",
|
||||
ts: "123",
|
||||
thread_ts: "123",
|
||||
},
|
||||
});
|
||||
|
||||
expect(isThreadReply).toBe(false);
|
||||
expect(replyThreadTs).toBeUndefined();
|
||||
expect(statusThreadTs).toBeUndefined();
|
||||
}
|
||||
|
||||
it("threads replies when message is already threaded", () => {
|
||||
const { replyThreadTs, statusThreadTs } = resolveSlackThreadTargets({
|
||||
replyToMode: "off",
|
||||
@@ -46,35 +62,11 @@ describe("resolveSlackThreadTargets", () => {
|
||||
});
|
||||
|
||||
it("does not treat auto-created top-level thread_ts as a real thread when mode is off", () => {
|
||||
const { replyThreadTs, statusThreadTs, isThreadReply } = resolveSlackThreadTargets({
|
||||
replyToMode: "off",
|
||||
message: {
|
||||
type: "message",
|
||||
channel: "C1",
|
||||
ts: "123",
|
||||
thread_ts: "123",
|
||||
},
|
||||
});
|
||||
|
||||
expect(isThreadReply).toBe(false);
|
||||
expect(replyThreadTs).toBeUndefined();
|
||||
expect(statusThreadTs).toBeUndefined();
|
||||
expectAutoCreatedTopLevelThreadTsBehavior("off");
|
||||
});
|
||||
|
||||
it("keeps first-mode behavior for auto-created top-level thread_ts", () => {
|
||||
const { replyThreadTs, statusThreadTs, isThreadReply } = resolveSlackThreadTargets({
|
||||
replyToMode: "first",
|
||||
message: {
|
||||
type: "message",
|
||||
channel: "C1",
|
||||
ts: "123",
|
||||
thread_ts: "123",
|
||||
},
|
||||
});
|
||||
|
||||
expect(isThreadReply).toBe(false);
|
||||
expect(replyThreadTs).toBeUndefined();
|
||||
expect(statusThreadTs).toBeUndefined();
|
||||
expectAutoCreatedTopLevelThreadTsBehavior("first");
|
||||
});
|
||||
|
||||
it("sets messageThreadId for top-level messages when replyToMode is all", () => {
|
||||
|
||||
Reference in New Issue
Block a user