it("stays in incoming threads for all replyToMode values", () => { for (const replyToMode of ["off", "first", "all", "batched"] as const) { for (const hasReplied of [false, true]) {
expect(
resolveSlackThreadTs({
replyToMode,
incomingThreadTs: threadTs,
messageTs,
hasReplied,
isThreadReply: true,
}),
).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");
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.