Add delivery failure handling to FASP jobs (#35723)
This commit is contained in:
@@ -5,12 +5,14 @@ require 'rails_helper'
|
||||
RSpec.describe Fasp::AccountSearchWorker, feature: :fasp do
|
||||
include ProviderRequestHelper
|
||||
|
||||
subject { described_class.new.perform('cats') }
|
||||
|
||||
let(:provider) { Fabricate(:account_search_fasp) }
|
||||
let(:account) { Fabricate(:account) }
|
||||
let(:fetch_service) { instance_double(ActivityPub::FetchRemoteActorService, call: true) }
|
||||
let(:path) { '/account_search/v0/search?term=cats&limit=10' }
|
||||
|
||||
let!(:stubbed_request) do
|
||||
path = '/account_search/v0/search?term=cats&limit=10'
|
||||
stub_provider_request(provider,
|
||||
method: :get,
|
||||
path:,
|
||||
@@ -25,7 +27,7 @@ RSpec.describe Fasp::AccountSearchWorker, feature: :fasp do
|
||||
end
|
||||
|
||||
it 'requests search results and fetches received account uris' do
|
||||
described_class.new.perform('cats')
|
||||
subject
|
||||
|
||||
expect(stubbed_request).to have_been_made
|
||||
expect(fetch_service).to have_received(:call).with('https://fedi.example.com/accounts/2')
|
||||
@@ -35,7 +37,7 @@ RSpec.describe Fasp::AccountSearchWorker, feature: :fasp do
|
||||
it 'marks a running async refresh as finished' do
|
||||
async_refresh = AsyncRefresh.create("fasp:account_search:#{Digest::MD5.base64digest('cats')}", count_results: true)
|
||||
|
||||
described_class.new.perform('cats')
|
||||
subject
|
||||
|
||||
expect(async_refresh.reload).to be_finished
|
||||
end
|
||||
@@ -43,8 +45,16 @@ RSpec.describe Fasp::AccountSearchWorker, feature: :fasp do
|
||||
it 'tracks the number of fetched accounts in the async refresh' do
|
||||
async_refresh = AsyncRefresh.create("fasp:account_search:#{Digest::MD5.base64digest('cats')}", count_results: true)
|
||||
|
||||
described_class.new.perform('cats')
|
||||
subject
|
||||
|
||||
expect(async_refresh.reload.result_count).to eq 2
|
||||
end
|
||||
|
||||
describe 'provider delivery failure handling' do
|
||||
let(:base_stubbed_request) do
|
||||
stub_request(:get, provider.url(path))
|
||||
end
|
||||
|
||||
it_behaves_like('worker handling fasp delivery failures')
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user