mirror of
https://github.com/lunaisnotaboy/mastodon.git
synced 2024-11-18 12:52:52 +00:00
2af03164cb
sidekiq-bulk's push_bulk can either accept arguments directly or run them through a block. Setting expectations on the result of evaluating the blocks allows testing more code (the block itself) and the test is moved closer to the *interface* of the tested code than its precise implementation.
117 lines
4.7 KiB
Ruby
117 lines
4.7 KiB
Ruby
require 'rails_helper'
|
|
|
|
RSpec.describe ActivityPub::FetchRepliesService, type: :service do
|
|
let(:actor) { Fabricate(:account, domain: 'example.com', uri: 'http://example.com/account') }
|
|
let(:status) { Fabricate(:status, account: actor) }
|
|
let(:collection_uri) { 'http://example.com/replies/1' }
|
|
|
|
let(:items) do
|
|
[
|
|
'http://example.com/self-reply-1',
|
|
'http://example.com/self-reply-2',
|
|
'http://example.com/self-reply-3',
|
|
'http://other.com/other-reply-1',
|
|
'http://other.com/other-reply-2',
|
|
'http://other.com/other-reply-3',
|
|
'http://example.com/self-reply-4',
|
|
'http://example.com/self-reply-5',
|
|
'http://example.com/self-reply-6',
|
|
]
|
|
end
|
|
|
|
let(:payload) do
|
|
{
|
|
'@context': 'https://www.w3.org/ns/activitystreams',
|
|
type: 'Collection',
|
|
id: collection_uri,
|
|
items: items,
|
|
}.with_indifferent_access
|
|
end
|
|
|
|
subject { described_class.new }
|
|
|
|
describe '#call' do
|
|
context 'when the payload is a Collection with inlined replies' do
|
|
context 'when passing the collection itself' do
|
|
it 'spawns workers for up to 5 replies on the same server' do
|
|
expect(FetchReplyWorker).to receive(:push_bulk).with(['http://example.com/self-reply-1', 'http://example.com/self-reply-2', 'http://example.com/self-reply-3', 'http://example.com/self-reply-4', 'http://example.com/self-reply-5'])
|
|
subject.call(status, payload)
|
|
end
|
|
end
|
|
|
|
context 'when passing the URL to the collection' do
|
|
before do
|
|
stub_request(:get, collection_uri).to_return(status: 200, body: Oj.dump(payload))
|
|
end
|
|
|
|
it 'spawns workers for up to 5 replies on the same server' do
|
|
expect(FetchReplyWorker).to receive(:push_bulk).with(['http://example.com/self-reply-1', 'http://example.com/self-reply-2', 'http://example.com/self-reply-3', 'http://example.com/self-reply-4', 'http://example.com/self-reply-5'])
|
|
subject.call(status, collection_uri)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'when the payload is an OrderedCollection with inlined replies' do
|
|
let(:payload) do
|
|
{
|
|
'@context': 'https://www.w3.org/ns/activitystreams',
|
|
type: 'OrderedCollection',
|
|
id: collection_uri,
|
|
orderedItems: items,
|
|
}.with_indifferent_access
|
|
end
|
|
|
|
context 'when passing the collection itself' do
|
|
it 'spawns workers for up to 5 replies on the same server' do
|
|
expect(FetchReplyWorker).to receive(:push_bulk).with(['http://example.com/self-reply-1', 'http://example.com/self-reply-2', 'http://example.com/self-reply-3', 'http://example.com/self-reply-4', 'http://example.com/self-reply-5'])
|
|
subject.call(status, payload)
|
|
end
|
|
end
|
|
|
|
context 'when passing the URL to the collection' do
|
|
before do
|
|
stub_request(:get, collection_uri).to_return(status: 200, body: Oj.dump(payload))
|
|
end
|
|
|
|
it 'spawns workers for up to 5 replies on the same server' do
|
|
expect(FetchReplyWorker).to receive(:push_bulk).with(['http://example.com/self-reply-1', 'http://example.com/self-reply-2', 'http://example.com/self-reply-3', 'http://example.com/self-reply-4', 'http://example.com/self-reply-5'])
|
|
subject.call(status, collection_uri)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'when the payload is a paginated Collection with inlined replies' do
|
|
let(:payload) do
|
|
{
|
|
'@context': 'https://www.w3.org/ns/activitystreams',
|
|
type: 'Collection',
|
|
id: collection_uri,
|
|
first: {
|
|
type: 'CollectionPage',
|
|
partOf: collection_uri,
|
|
items: items,
|
|
}
|
|
}.with_indifferent_access
|
|
end
|
|
|
|
context 'when passing the collection itself' do
|
|
it 'spawns workers for up to 5 replies on the same server' do
|
|
expect(FetchReplyWorker).to receive(:push_bulk).with(['http://example.com/self-reply-1', 'http://example.com/self-reply-2', 'http://example.com/self-reply-3', 'http://example.com/self-reply-4', 'http://example.com/self-reply-5'])
|
|
subject.call(status, payload)
|
|
end
|
|
end
|
|
|
|
context 'when passing the URL to the collection' do
|
|
before do
|
|
stub_request(:get, collection_uri).to_return(status: 200, body: Oj.dump(payload))
|
|
end
|
|
|
|
it 'spawns workers for up to 5 replies on the same server' do
|
|
expect(FetchReplyWorker).to receive(:push_bulk).with(['http://example.com/self-reply-1', 'http://example.com/self-reply-2', 'http://example.com/self-reply-3', 'http://example.com/self-reply-4', 'http://example.com/self-reply-5'])
|
|
subject.call(status, collection_uri)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|