|
|
|
@ -5,12 +5,14 @@ RSpec.describe AfterBlockService, type: :service do |
|
|
|
|
-> { described_class.new.call(account, target_account) } |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
let(:account) { Fabricate(:account) } |
|
|
|
|
let(:target_account) { Fabricate(:account) } |
|
|
|
|
let(:account) { Fabricate(:account) } |
|
|
|
|
let(:target_account) { Fabricate(:account) } |
|
|
|
|
let(:status) { Fabricate(:status, account: target_account) } |
|
|
|
|
let(:other_status) { Fabricate(:status, account: target_account) } |
|
|
|
|
let(:other_account_status) { Fabricate(:status) } |
|
|
|
|
let(:other_account_reblog) { Fabricate(:status, reblog_of_id: other_status.id) } |
|
|
|
|
|
|
|
|
|
describe 'home timeline' do |
|
|
|
|
let(:status) { Fabricate(:status, account: target_account) } |
|
|
|
|
let(:other_account_status) { Fabricate(:status) } |
|
|
|
|
let(:home_timeline_key) { FeedManager.instance.key(:home, account.id) } |
|
|
|
|
|
|
|
|
|
before do |
|
|
|
@ -20,10 +22,30 @@ RSpec.describe AfterBlockService, type: :service do |
|
|
|
|
it "clears account's statuses" do |
|
|
|
|
FeedManager.instance.push_to_home(account, status) |
|
|
|
|
FeedManager.instance.push_to_home(account, other_account_status) |
|
|
|
|
FeedManager.instance.push_to_home(account, other_account_reblog) |
|
|
|
|
|
|
|
|
|
is_expected.to change { |
|
|
|
|
Redis.current.zrange(home_timeline_key, 0, -1) |
|
|
|
|
}.from([status.id.to_s, other_account_status.id.to_s]).to([other_account_status.id.to_s]) |
|
|
|
|
}.from([status.id.to_s, other_account_status.id.to_s, other_account_reblog.id.to_s]).to([other_account_status.id.to_s]) |
|
|
|
|
end |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
describe 'lists' do |
|
|
|
|
let(:list) { Fabricate(:list, account: account) } |
|
|
|
|
let(:list_timeline_key) { FeedManager.instance.key(:list, list.id) } |
|
|
|
|
|
|
|
|
|
before do |
|
|
|
|
Redis.current.del(list_timeline_key) |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
it "clears account's statuses" do |
|
|
|
|
FeedManager.instance.push_to_list(list, status) |
|
|
|
|
FeedManager.instance.push_to_list(list, other_account_status) |
|
|
|
|
FeedManager.instance.push_to_list(list, other_account_reblog) |
|
|
|
|
|
|
|
|
|
is_expected.to change { |
|
|
|
|
Redis.current.zrange(list_timeline_key, 0, -1) |
|
|
|
|
}.from([status.id.to_s, other_account_status.id.to_s, other_account_reblog.id.to_s]).to([other_account_status.id.to_s]) |
|
|
|
|
end |
|
|
|
|
end |
|
|
|
|
end |
|
|
|
|