diff --git a/src/scripts/federal-holidays.js b/src/scripts/federal-holidays.js index c689b8b..478d506 100644 --- a/src/scripts/federal-holidays.js +++ b/src/scripts/federal-holidays.js @@ -40,8 +40,12 @@ module.exports = (app) => { }, })); - app.message(directMention(), /next (federal )?holiday/i, ({ say }) => { - say(getHolidayText()); - incrementStats("next federal holiday request"); - }); + app.message( + directMention(), + /next (federal )?holiday/i, + ({ event: { thread_ts: thread, ts }, say }) => { + say({ text: getHolidayText(), thread_ts: thread ?? ts }); + incrementStats("next federal holiday request"); + }, + ); }; diff --git a/src/scripts/federal-holidays.test.js b/src/scripts/federal-holidays.test.js index 7debab8..243d850 100644 --- a/src/scripts/federal-holidays.test.js +++ b/src/scripts/federal-holidays.test.js @@ -83,12 +83,13 @@ describe("federal holidays bot", () => { name: "Test Holiday day", }); - handler({ say }); + handler({ event: { ts: 0 }, say }); expect(say.mock.calls.length).toBe(1); - expect(say).toHaveBeenCalledWith( - "The next federal holiday is Test Holiday day in 1 days on Friday, January 2nd", - ); + expect(say).toHaveBeenCalledWith({ + text: "The next federal holiday is Test Holiday day in 1 days on Friday, January 2nd", + thread_ts: 0, + }); }); it("uses an alternate name, if provided", () => { @@ -102,12 +103,13 @@ describe("federal holidays bot", () => { alsoObservedAs: "Other holiday day day day", }); - handler({ say }); + handler({ event: { thread_ts: "thread", ts: 12345 }, say }); expect(say.mock.calls.length).toBe(1); - expect(say).toHaveBeenCalledWith( - "The next federal holiday is Other holiday day day day in 1 days on Friday, January 2nd", - ); + expect(say).toHaveBeenCalledWith({ + text: "The next federal holiday is Other holiday day day day in 1 days on Friday, January 2nd", + thread_ts: "thread", + }); }); }); @@ -122,12 +124,13 @@ describe("federal holidays bot", () => { name: "Christmas Day", }); - handler({ say }); + handler({ event: { ts: 12345 }, say }); expect(say.mock.calls.length).toBe(1); - expect(say).toHaveBeenCalledWith( - "The next federal holiday is Christmas Day :christmas_tree: in 1 days on Friday, January 2nd", - ); + expect(say).toHaveBeenCalledWith({ + text: "The next federal holiday is Christmas Day :christmas_tree: in 1 days on Friday, January 2nd", + thread_ts: 12345, + }); }); it("does not include the emoji if the holiday does not have one", () => { @@ -141,12 +144,13 @@ describe("federal holidays bot", () => { alsoObservedAs: "Indigenous Peoples' Day", }); - handler({ say }); + handler({ event: { ts: 0 }, say }); expect(say.mock.calls.length).toBe(1); - expect(say).toHaveBeenCalledWith( - "The next federal holiday is Indigenous Peoples' Day in 1 days on Friday, January 2nd", - ); + expect(say).toHaveBeenCalledWith({ + text: "The next federal holiday is Indigenous Peoples' Day in 1 days on Friday, January 2nd", + thread_ts: 0, + }); }); }); });