Add basic coverage for `UnmuteService` class (#29330)

main-rebase-security-fix
Matt Jankowski 2024-02-22 05:48:09 -05:00 committed by GitHub
parent a69fe534e3
commit f70905f127
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 46 additions and 0 deletions

View File

@ -0,0 +1,46 @@
# frozen_string_literal: true
require 'rails_helper'
RSpec.describe UnmuteService do
describe '#call' do
let!(:account) { Fabricate(:account) }
let!(:target_account) { Fabricate(:account) }
context 'when account is muting target account' do
before { Fabricate :mute, account: account, target_account: target_account }
context 'when account follows target_account' do
before { Fabricate :follow, account: account, target_account: target_account }
it 'removes the account mute and sets up a merge' do
expect { subject.call(account, target_account) }
.to remove_account_mute
expect(MergeWorker).to have_enqueued_sidekiq_job(target_account.id, account.id)
end
end
context 'when account does not follow target_account' do
it 'removes the account mute and does not create a merge' do
expect { subject.call(account, target_account) }
.to remove_account_mute
expect(MergeWorker).to_not have_enqueued_sidekiq_job
end
end
def remove_account_mute
change { account.reload.muting?(target_account) }
.from(true)
.to(false)
end
end
context 'when account is not muting target account' do
it 'does nothing and returns' do
expect { subject.call(account, target_account) }
.to_not(change { account.reload.muting?(target_account) })
expect(MergeWorker).to_not have_enqueued_sidekiq_job
end
end
end
end