FIX: correct in_thread? message logic (#27151)

A message is in a thread if:
- it has a thread_id
- it is in threading_enabled channel OR the associated thread is marked as `force`
This commit is contained in:
Joffrey JAFFEUX 2024-05-23 11:08:55 +02:00 committed by GitHub
parent f84eda7c8d
commit b3802e12f0
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 35 additions and 1 deletions

View File

@ -266,7 +266,7 @@ module Chat
end end
def in_thread? def in_thread?
self.thread_id.present? && self.chat_channel.threading_enabled self.thread_id.present? && (self.chat_channel.threading_enabled || self.thread&.force)
end end
def thread_reply? def thread_reply?

View File

@ -11,6 +11,40 @@ describe Chat::Message do
it { is_expected.to validate_length_of(:cooked).is_at_most(20_000) } it { is_expected.to validate_length_of(:cooked).is_at_most(20_000) }
end end
describe ".in_thread?" do
context "when in a thread enabled channel" do
fab!(:message) do
Fabricate(
:chat_message,
thread_id: 1,
chat_channel: Fabricate(:chat_channel, threading_enabled: true),
)
end
it "returns true for messages in a thread" do
expect(message.in_thread?).to eq(true)
end
it "returns false for messages not in a thread" do
message.update!(thread_id: nil)
expect(message.in_thread?).to eq(false)
end
end
context "when the thread is forced" do
fab!(:message) { Fabricate(:chat_message, thread: Fabricate(:chat_thread, force: true)) }
it "returns true for messages in a thread" do
expect(message.in_thread?).to eq(true)
end
it "returns false for messages not in a thread" do
message.update!(thread_id: nil)
expect(message.in_thread?).to eq(false)
end
end
end
describe ".cook" do describe ".cook" do
it "does not support HTML tags" do it "does not support HTML tags" do
cooked = described_class.cook("<h1>test</h1>") cooked = described_class.cook("<h1>test</h1>")