summaryrefslogtreecommitdiffstats
path: root/spec/lib
diff options
context:
space:
mode:
authorThibG <thib@sitedethib.com>2020-07-17 07:07:54 +0200
committerGitHub <noreply@github.com>2020-07-17 07:07:54 +0200
commit322d74fc2aa9db2d05e5bad944661c6edf1660e1 (patch)
tree784d2a043a505c7edac87a556280bc579247eb82 /spec/lib
parent85bc0f9639c9c1ecccfa6963929b6c405fb8452c (diff)
Fix boosted toots from blocked account not being retroactively removed from TL (#14339)
* Fix boosted toots from blocked account not being retroactively removed from TL Fixes #14301 * Add test for clear_from_timeline
Diffstat (limited to 'spec/lib')
-rw-r--r--spec/lib/feed_manager_spec.rb25
1 files changed, 25 insertions, 0 deletions
diff --git a/spec/lib/feed_manager_spec.rb b/spec/lib/feed_manager_spec.rb
index b996997b136..22eddd2ab6e 100644
--- a/spec/lib/feed_manager_spec.rb
+++ b/spec/lib/feed_manager_spec.rb
@@ -429,4 +429,29 @@ RSpec.describe FeedManager do
expect(Redis.current).to have_received(:publish).with("timeline:#{receiver.id}", deletion)
end
end
+
+ describe '#clear_from_timeline' do
+ let(:account) { Fabricate(:account) }
+ let(:followed_account) { Fabricate(:account) }
+ let(:target_account) { Fabricate(:account) }
+ let(:status_1) { Fabricate(:status, account: followed_account) }
+ let(:status_2) { Fabricate(:status, account: target_account) }
+ let(:status_3) { Fabricate(:status, account: followed_account, mentions: [Fabricate(:mention, account: target_account)]) }
+ let(:status_4) { Fabricate(:status, mentions: [Fabricate(:mention, account: target_account)]) }
+ let(:status_5) { Fabricate(:status, account: followed_account, reblog: status_4) }
+ let(:status_6) { Fabricate(:status, account: followed_account, reblog: status_2) }
+ let(:status_7) { Fabricate(:status, account: followed_account) }
+
+ before do
+ [status_1, status_3, status_5, status_6, status_7].each do |status|
+ Redis.current.zadd("feed:home:#{account.id}", status.id, status.id)
+ end
+ end
+
+ it 'correctly cleans the timeline' do
+ FeedManager.instance.clear_from_timeline(account, target_account)
+
+ expect(Redis.current.zrange("feed:home:#{account.id}", 0, -1)).to eq [status_1.id.to_s, status_7.id.to_s]
+ end
+ end
end