2021-12-27 18:53:59 +01:00
# frozen_string_literal: true
require 'rails_helper'
describe ShareWorker do
let ( :user ) { FactoryBot . create ( :user ) }
let ( :answer ) { FactoryBot . create ( :answer , user : user ) }
2021-12-27 23:02:32 +01:00
let! ( :service ) { Services :: Twitter . create! ( type : 'Services::Twitter' ,
user : user ) }
2021-12-27 18:53:59 +01:00
2021-12-28 03:03:59 +01:00
before do
stub_const ( " APP_CONFIG " , {
'hostname' = > 'example.com' ,
'anonymous_name' = > 'Anonymous' ,
'https' = > true ,
'items_per_page' = > 5 ,
'sharing' = > {
'twitter' = > {
'consumer_key' = > '' ,
}
}
} )
end
2021-12-27 18:53:59 +01:00
describe " # perform " do
2022-06-21 20:02:49 +02:00
before do
allow ( Sidekiq . logger ) . to receive ( :info )
end
subject do
2021-12-27 23:02:32 +01:00
Sidekiq :: Testing . fake! do
ShareWorker . perform_async ( user . id , answer . id , 'twitter' )
end
2022-06-21 20:02:49 +02:00
end
2021-12-27 18:53:59 +01:00
context 'when answer doesn\'t exist' do
it 'prevents the job from retrying and logs a message' do
answer . destroy!
2021-12-27 23:02:32 +01:00
expect { subject } . to change ( ShareWorker . jobs , :size ) . by ( 1 )
expect { ShareWorker . drain } . to change ( ShareWorker . jobs , :size ) . by ( - 1 )
2022-06-21 20:02:49 +02:00
expect ( Sidekiq . logger ) . to have_received ( :info ) . with ( " Tried to post answer # #{ answer . id } for user # #{ user . id } to Twitter but the user/answer/service did not exist (likely deleted), will not retry. " )
2021-12-27 23:02:32 +01:00
end
end
context 'when answer exists' do
2021-12-28 03:59:45 +01:00
it 'handles Twitter::Error::DuplicateStatus' do
allow_any_instance_of ( Services :: Twitter ) . to receive ( :post ) . with ( answer ) . and_raise ( Twitter :: Error :: DuplicateStatus )
subject
ShareWorker . drain
2022-06-21 20:02:49 +02:00
expect ( Sidekiq . logger ) . to have_received ( :info ) . with ( " Tried to post answer # #{ answer . id } from user # #{ user . id } to Twitter but the status was already posted. " )
2021-12-28 03:59:45 +01:00
end
it 'handles Twitter::Error::Unauthorized' do
allow_any_instance_of ( Services :: Twitter ) . to receive ( :post ) . with ( answer ) . and_raise ( Twitter :: Error :: Unauthorized )
subject
ShareWorker . drain
2022-06-21 20:02:49 +02:00
expect ( Sidekiq . logger ) . to have_received ( :info ) . with ( " Tried to post answer # #{ answer . id } from user # #{ user . id } to Twitter but the token has exired or been revoked. " )
2021-12-28 03:59:45 +01:00
end
2021-12-27 23:02:32 +01:00
it 'retries on unhandled exceptions' do
expect { subject } . to change ( ShareWorker . jobs , :size ) . by ( 1 )
2021-12-28 03:03:59 +01:00
expect { ShareWorker . drain } . to raise_error ( Twitter :: Error :: BadRequest )
2022-06-21 20:02:49 +02:00
expect ( Sidekiq . logger ) . to have_received ( :info )
2021-12-27 18:53:59 +01:00
end
end
end
end