Spec feed insert worker (#2965)
* Spec for feed insert worker when missing records * more specs! * Refactor feed insert workermaster
parent
2fba4196ef
commit
cc9a6a710f
@ -0,0 +1,52 @@ |
||||
# frozen_string_literal: true |
||||
|
||||
require 'rails_helper' |
||||
|
||||
describe FeedInsertWorker do |
||||
subject { described_class.new } |
||||
|
||||
describe 'perform' do |
||||
let(:follower) { Fabricate(:account) } |
||||
let(:status) { Fabricate(:status) } |
||||
|
||||
context 'when there are no records' do |
||||
it 'skips push with missing status' do |
||||
instance = double(push: nil) |
||||
allow(FeedManager).to receive(:instance).and_return(instance) |
||||
result = subject.perform(nil, follower.id) |
||||
|
||||
expect(result).to eq true |
||||
expect(instance).not_to have_received(:push) |
||||
end |
||||
|
||||
it 'skips push with missing account' do |
||||
instance = double(push: nil) |
||||
allow(FeedManager).to receive(:instance).and_return(instance) |
||||
result = subject.perform(status.id, nil) |
||||
|
||||
expect(result).to eq true |
||||
expect(instance).not_to have_received(:push) |
||||
end |
||||
end |
||||
|
||||
context 'when there are real records' do |
||||
it 'skips the push when there is a filter' do |
||||
instance = double(push: nil, filter?: true) |
||||
allow(FeedManager).to receive(:instance).and_return(instance) |
||||
result = subject.perform(status.id, follower.id) |
||||
|
||||
expect(result).to be_nil |
||||
expect(instance).not_to have_received(:push) |
||||
end |
||||
|
||||
it 'pushes the status onto the home timeline without filter' do |
||||
instance = double(push: nil, filter?: false) |
||||
allow(FeedManager).to receive(:instance).and_return(instance) |
||||
result = subject.perform(status.id, follower.id) |
||||
|
||||
expect(result).to be_nil |
||||
expect(instance).to have_received(:push).with(:home, follower, status) |
||||
end |
||||
end |
||||
end |
||||
end |
Loading…
Reference in new issue