Refactor fetching of remote resources (#11251)
This commit is contained in:
parent
d04c584159
commit
5d3feed191
13 changed files with 142 additions and 216 deletions
|
@ -4,6 +4,7 @@ RSpec.describe FetchRemoteAccountService, type: :service do
|
|||
let(:url) { 'https://example.com/alice' }
|
||||
let(:prefetched_body) { nil }
|
||||
let(:protocol) { :ostatus }
|
||||
|
||||
subject { FetchRemoteAccountService.new.call(url, prefetched_body, protocol) }
|
||||
|
||||
let(:actor) do
|
||||
|
|
|
@ -1,9 +1,11 @@
|
|||
require 'rails_helper'
|
||||
|
||||
RSpec.describe FetchAtomService, type: :service do
|
||||
RSpec.describe FetchResourceService, type: :service do
|
||||
let!(:representative) { Fabricate(:account) }
|
||||
|
||||
describe '#call' do
|
||||
let(:url) { 'http://example.com' }
|
||||
subject { FetchAtomService.new.call(url) }
|
||||
subject { described_class.new.call(url) }
|
||||
|
||||
context 'url is blank' do
|
||||
let(:url) { '' }
|
||||
|
@ -23,8 +25,7 @@ RSpec.describe FetchAtomService, type: :service do
|
|||
allow(Request).to receive_message_chain(:new, :add_headers, :perform).and_raise(OpenSSL::SSL::SSLError)
|
||||
end
|
||||
|
||||
it 'output log and return nil' do
|
||||
expect_any_instance_of(ActiveSupport::Logger).to receive(:debug).with('SSL error: OpenSSL::SSL::SSLError')
|
||||
it 'return nil' do
|
||||
is_expected.to be_nil
|
||||
end
|
||||
end
|
||||
|
@ -34,8 +35,7 @@ RSpec.describe FetchAtomService, type: :service do
|
|||
allow(Request).to receive_message_chain(:new, :add_headers, :perform).and_raise(HTTP::ConnectionError)
|
||||
end
|
||||
|
||||
it 'output log and return nil' do
|
||||
expect_any_instance_of(ActiveSupport::Logger).to receive(:debug).with('HTTP ConnectionError: HTTP::ConnectionError')
|
||||
it 'return nil' do
|
||||
is_expected.to be_nil
|
||||
end
|
||||
end
|
||||
|
@ -57,7 +57,7 @@ RSpec.describe FetchAtomService, type: :service do
|
|||
context 'content type is application/atom+xml' do
|
||||
let(:content_type) { 'application/atom+xml' }
|
||||
|
||||
it { is_expected.to eq [url, { :prefetched_body => "" }, :ostatus] }
|
||||
it { is_expected.to eq nil }
|
||||
end
|
||||
|
||||
context 'content_type is activity+json' do
|
|
@ -6,48 +6,14 @@ describe ResolveURLService, type: :service do
|
|||
subject { described_class.new }
|
||||
|
||||
describe '#call' do
|
||||
it 'returns nil when there is no atom url' do
|
||||
url = 'http://example.com/missing-atom'
|
||||
it 'returns nil when there is no resource url' do
|
||||
url = 'http://example.com/missing-resource'
|
||||
service = double
|
||||
allow(FetchAtomService).to receive(:new).and_return service
|
||||
|
||||
allow(FetchResourceService).to receive(:new).and_return service
|
||||
allow(service).to receive(:call).with(url).and_return(nil)
|
||||
|
||||
result = subject.call(url)
|
||||
expect(result).to be_nil
|
||||
end
|
||||
|
||||
it 'fetches remote accounts for feed types' do
|
||||
url = 'http://example.com/atom-feed'
|
||||
service = double
|
||||
allow(FetchAtomService).to receive(:new).and_return service
|
||||
feed_url = 'http://feed-url'
|
||||
feed_content = '<feed>contents</feed>'
|
||||
allow(service).to receive(:call).with(url).and_return([feed_url, { prefetched_body: feed_content }])
|
||||
|
||||
account_service = double
|
||||
allow(FetchRemoteAccountService).to receive(:new).and_return(account_service)
|
||||
allow(account_service).to receive(:call)
|
||||
|
||||
_result = subject.call(url)
|
||||
|
||||
expect(account_service).to have_received(:call).with(feed_url, feed_content, nil)
|
||||
end
|
||||
|
||||
it 'fetches remote statuses for entry types' do
|
||||
url = 'http://example.com/atom-entry'
|
||||
service = double
|
||||
allow(FetchAtomService).to receive(:new).and_return service
|
||||
feed_url = 'http://feed-url'
|
||||
feed_content = '<entry>contents</entry>'
|
||||
allow(service).to receive(:call).with(url).and_return([feed_url, { prefetched_body: feed_content }])
|
||||
|
||||
account_service = double
|
||||
allow(FetchRemoteStatusService).to receive(:new).and_return(account_service)
|
||||
allow(account_service).to receive(:call)
|
||||
|
||||
_result = subject.call(url)
|
||||
|
||||
expect(account_service).to have_received(:call).with(feed_url, feed_content, nil)
|
||||
expect(subject.call(url)).to be_nil
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue