|
55 | 55 | end |
56 | 56 | end |
57 | 57 |
|
| 58 | + context "marking message as read for sender" do |
| 59 | + it "marks the message as read for registered user sender" do |
| 60 | + builder.process! |
| 61 | + |
| 62 | + expect(MessageReadRange.covering?(user: sender_user, topic: topic, message_id: message.id)).to be true |
| 63 | + end |
| 64 | + |
| 65 | + it "marks thread awareness for registered user sender" do |
| 66 | + builder.process! |
| 67 | + |
| 68 | + expect(ThreadAwareness.covering?(user: sender_user, topic: topic, message_id: message.id)).to be true |
| 69 | + end |
| 70 | + |
| 71 | + it "does not mark message as read for guest sender" do |
| 72 | + guest_alias = create(:alias, user: nil) |
| 73 | + guest_message = create(:message, topic: topic, sender: guest_alias) |
| 74 | + guest_builder = described_class.new(guest_message) |
| 75 | + |
| 76 | + expect { |
| 77 | + guest_builder.process! |
| 78 | + }.not_to change { MessageReadRange.count } |
| 79 | + end |
| 80 | + |
| 81 | + it "does not mark thread awareness for guest sender" do |
| 82 | + guest_alias = create(:alias, user: nil) |
| 83 | + guest_message = create(:message, topic: topic, sender: guest_alias) |
| 84 | + guest_builder = described_class.new(guest_message) |
| 85 | + |
| 86 | + expect { |
| 87 | + guest_builder.process! |
| 88 | + }.not_to change { ThreadAwareness.count } |
| 89 | + end |
| 90 | + |
| 91 | + it "extends existing thread awareness" do |
| 92 | + # Create initial awareness |
| 93 | + ThreadAwareness.mark_until(user: sender_user, topic: topic, until_message_id: message.id - 10) |
| 94 | + |
| 95 | + builder.process! |
| 96 | + |
| 97 | + awareness = ThreadAwareness.find_by(user: sender_user, topic: topic) |
| 98 | + expect(awareness.aware_until_message_id).to eq(message.id) |
| 99 | + end |
| 100 | + end |
| 101 | + |
58 | 102 | context "activity creation" do |
59 | 103 | let(:starring_user1) { create(:user) } |
60 | 104 | let(:starring_user2) { create(:user) } |
|
0 commit comments