mirror of https://github.com/mastodon/mastodon
Spec and refactor for pubsubhubbub/unsubscribe service (#2946)
* Add coverage for pubsub unsubscribe service * Refactor pubsub unsubscribe servicepull/2951/head
parent
d5cabfe5c6
commit
441d6dc734
@ -1,15 +1,31 @@
|
|||||||
# frozen_string_literal: true
|
# frozen_string_literal: true
|
||||||
|
|
||||||
class Pubsubhubbub::UnsubscribeService < BaseService
|
class Pubsubhubbub::UnsubscribeService < BaseService
|
||||||
def call(account, callback)
|
attr_reader :account, :callback_url
|
||||||
return ['Invalid topic URL', 422] if account.nil?
|
|
||||||
|
|
||||||
subscription = Subscription.find_by(account: account, callback_url: callback)
|
def call(account, callback_url)
|
||||||
|
@account = account
|
||||||
|
@callback_url = callback_url
|
||||||
|
|
||||||
unless subscription.nil?
|
process_unsubscribe
|
||||||
Pubsubhubbub::ConfirmationWorker.perform_async(subscription.id, 'unsubscribe')
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def process_unsubscribe
|
||||||
|
if account.nil?
|
||||||
|
['Invalid topic URL', 422]
|
||||||
|
else
|
||||||
|
confirm_unsubscribe unless subscription.nil?
|
||||||
|
['', 202]
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def confirm_unsubscribe
|
||||||
|
Pubsubhubbub::ConfirmationWorker.perform_async(subscription.id, 'unsubscribe')
|
||||||
|
end
|
||||||
|
|
||||||
['', 202]
|
def subscription
|
||||||
|
@_subscription ||= Subscription.find_by(account: account, callback_url: callback_url)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -0,0 +1,46 @@
|
|||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
require 'rails_helper'
|
||||||
|
|
||||||
|
describe Pubsubhubbub::UnsubscribeService do
|
||||||
|
describe '#call' do
|
||||||
|
subject { described_class.new }
|
||||||
|
|
||||||
|
context 'with a nil account' do
|
||||||
|
it 'returns an invalid topic status' do
|
||||||
|
result = subject.call(nil, 'callback.host')
|
||||||
|
|
||||||
|
expect(result).to eq invalid_topic_status
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with a valid account' do
|
||||||
|
let(:account) { Fabricate(:account) }
|
||||||
|
|
||||||
|
it 'returns a valid topic status and does not run confirm when no subscription' do
|
||||||
|
allow(Pubsubhubbub::ConfirmationWorker).to receive(:perform_async).and_return(nil)
|
||||||
|
result = subject.call(account, 'callback.host')
|
||||||
|
|
||||||
|
expect(result).to eq valid_topic_status
|
||||||
|
expect(Pubsubhubbub::ConfirmationWorker).not_to have_received(:perform_async)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'returns a valid topic status and does run confirm when there is a subscription' do
|
||||||
|
subscription = Fabricate(:subscription, account: account, callback_url: 'callback.host')
|
||||||
|
allow(Pubsubhubbub::ConfirmationWorker).to receive(:perform_async).and_return(nil)
|
||||||
|
result = subject.call(account, 'callback.host')
|
||||||
|
|
||||||
|
expect(result).to eq valid_topic_status
|
||||||
|
expect(Pubsubhubbub::ConfirmationWorker).to have_received(:perform_async).with(subscription.id, 'unsubscribe')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def invalid_topic_status
|
||||||
|
['Invalid topic URL', 422]
|
||||||
|
end
|
||||||
|
|
||||||
|
def valid_topic_status
|
||||||
|
['', 202]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in New Issue