Fix error when accepting appeal for sensitive posts deleted in the meantime (#32037)
Co-authored-by: David Roetzel <david@roetzel.de>
This commit is contained in:
parent
0a6b75b71e
commit
c36a76b9eb
2 changed files with 45 additions and 17 deletions
|
@ -53,7 +53,7 @@ class ApproveAppealService < BaseService
|
||||||
|
|
||||||
def undo_mark_statuses_as_sensitive!
|
def undo_mark_statuses_as_sensitive!
|
||||||
representative_account = Account.representative
|
representative_account = Account.representative
|
||||||
@strike.statuses.includes(:media_attachments).find_each do |status|
|
@strike.statuses.kept.includes(:media_attachments).reorder(nil).find_each do |status|
|
||||||
UpdateStatusService.new.call(status, representative_account.id, sensitive: false) if status.with_media?
|
UpdateStatusService.new.call(status, representative_account.id, sensitive: false) if status.with_media?
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -4,27 +4,55 @@ require 'rails_helper'
|
||||||
|
|
||||||
RSpec.describe ApproveAppealService do
|
RSpec.describe ApproveAppealService do
|
||||||
describe '#call' do
|
describe '#call' do
|
||||||
context 'with an existing appeal' do
|
let(:appeal) { Fabricate(:appeal) }
|
||||||
let(:appeal) { Fabricate(:appeal) }
|
let(:account) { Fabricate(:account) }
|
||||||
let(:account) { Fabricate(:account) }
|
|
||||||
|
|
||||||
it 'processes the appeal approval' do
|
it 'processes the appeal approval' do
|
||||||
expect { subject.call(appeal, account) }
|
expect { subject.call(appeal, account) }
|
||||||
.to mark_overruled
|
.to mark_overruled
|
||||||
.and record_approver
|
.and record_approver
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with an appeal about then-deleted posts marked as sensitive by moderators' do
|
||||||
|
let(:target_account) { Fabricate(:account) }
|
||||||
|
let(:appeal) { Fabricate(:appeal, strike: strike, account: target_account) }
|
||||||
|
let(:deleted_media) { Fabricate(:media_attachment, type: :video, status: Fabricate(:status, account: target_account), account: target_account) }
|
||||||
|
let(:kept_media) { Fabricate(:media_attachment, type: :video, status: Fabricate(:status, account: target_account), account: target_account) }
|
||||||
|
let(:strike) { Fabricate(:account_warning, target_account: target_account, action: :mark_statuses_as_sensitive, status_ids: [deleted_media.status.id, kept_media.status.id]) }
|
||||||
|
|
||||||
|
before do
|
||||||
|
target_account.unsuspend!
|
||||||
|
deleted_media.status.discard!
|
||||||
end
|
end
|
||||||
|
|
||||||
def mark_overruled
|
it 'approves the appeal, marks the statuses as not sensitive and notifies target account about the approval', :inline_jobs do
|
||||||
change(appeal.strike, :overruled_at)
|
emails = capture_emails { subject.call(appeal, account) }
|
||||||
.from(nil)
|
|
||||||
.to(be > 1.minute.ago)
|
|
||||||
end
|
|
||||||
|
|
||||||
def record_approver
|
expect(appeal.reload).to be_approved
|
||||||
change(appeal, :approved_by_account)
|
expect(strike.reload).to be_overruled
|
||||||
.from(nil)
|
|
||||||
.to(account)
|
expect(kept_media.status.reload).to_not be_sensitive
|
||||||
|
|
||||||
|
expect(emails.size)
|
||||||
|
.to eq(1)
|
||||||
|
expect(emails.first)
|
||||||
|
.to have_attributes(
|
||||||
|
to: contain_exactly(target_account.user.email),
|
||||||
|
subject: eq(I18n.t('user_mailer.appeal_approved.subject', date: I18n.l(appeal.created_at)))
|
||||||
|
)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def mark_overruled
|
||||||
|
change(appeal.strike, :overruled_at)
|
||||||
|
.from(nil)
|
||||||
|
.to(be > 1.minute.ago)
|
||||||
|
end
|
||||||
|
|
||||||
|
def record_approver
|
||||||
|
change(appeal, :approved_by_account)
|
||||||
|
.from(nil)
|
||||||
|
.to(account)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue