Fix reports not being closed when performing batch suspensions (#24988)
This commit is contained in:
		| @@ -123,7 +123,18 @@ class Form::AccountBatch | |||||||
|       account: current_account, |       account: current_account, | ||||||
|       action: :suspend |       action: :suspend | ||||||
|     ) |     ) | ||||||
|  |  | ||||||
|     Admin::SuspensionWorker.perform_async(account.id) |     Admin::SuspensionWorker.perform_async(account.id) | ||||||
|  |  | ||||||
|  |     # Suspending a single account closes their associated reports, so | ||||||
|  |     # mass-suspending would be consistent. | ||||||
|  |     Report.where(target_account: account).unresolved.find_each do |report| | ||||||
|  |       authorize(report, :update?) | ||||||
|  |       log_action(:resolve, report) | ||||||
|  |       report.resolve!(current_account) | ||||||
|  |     rescue Mastodon::NotPermittedError | ||||||
|  |       # This should not happen, but just in case, do not fail early | ||||||
|  |     end | ||||||
|   end |   end | ||||||
|  |  | ||||||
|   def approve_account(account) |   def approve_account(account) | ||||||
|   | |||||||
							
								
								
									
										63
									
								
								spec/models/form/account_batch_spec.rb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								spec/models/form/account_batch_spec.rb
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,63 @@ | |||||||
|  | # frozen_string_literal: true | ||||||
|  |  | ||||||
|  | require 'rails_helper' | ||||||
|  |  | ||||||
|  | RSpec.describe Form::AccountBatch do | ||||||
|  |   let(:account_batch) { described_class.new } | ||||||
|  |  | ||||||
|  |   describe '#save' do | ||||||
|  |     subject           { account_batch.save } | ||||||
|  |  | ||||||
|  |     let(:account)     { Fabricate(:user, role: UserRole.find_by(name: 'Admin')).account } | ||||||
|  |     let(:account_ids) { [] } | ||||||
|  |     let(:query)       { Account.none } | ||||||
|  |  | ||||||
|  |     before do | ||||||
|  |       account_batch.assign_attributes( | ||||||
|  |         action: action, | ||||||
|  |         current_account: account, | ||||||
|  |         account_ids: account_ids, | ||||||
|  |         query: query, | ||||||
|  |         select_all_matching: select_all_matching | ||||||
|  |       ) | ||||||
|  |     end | ||||||
|  |  | ||||||
|  |     context 'when action is "suspend"' do | ||||||
|  |       let(:action) { 'suspend' } | ||||||
|  |  | ||||||
|  |       let(:target_account)  { Fabricate(:account) } | ||||||
|  |       let(:target_account2) { Fabricate(:account) } | ||||||
|  |  | ||||||
|  |       before do | ||||||
|  |         Fabricate(:report, target_account: target_account) | ||||||
|  |         Fabricate(:report, target_account: target_account2) | ||||||
|  |       end | ||||||
|  |  | ||||||
|  |       context 'when accounts are passed as account_ids' do | ||||||
|  |         let(:select_all_matching) { '0' } | ||||||
|  |         let(:account_ids)         { [target_account.id, target_account2.id] } | ||||||
|  |  | ||||||
|  |         it 'suspends the expected users' do | ||||||
|  |           expect { subject }.to change { [target_account.reload.suspended?, target_account2.reload.suspended?] }.from([false, false]).to([true, true]) | ||||||
|  |         end | ||||||
|  |  | ||||||
|  |         it 'closes open reports targeting the suspended users' do | ||||||
|  |           expect { subject }.to change { Report.unresolved.where(target_account: [target_account, target_account2]).count }.from(2).to(0) | ||||||
|  |         end | ||||||
|  |       end | ||||||
|  |  | ||||||
|  |       context 'when accounts are passed as a query' do | ||||||
|  |         let(:select_all_matching) { '1' } | ||||||
|  |         let(:query)               { Account.where(id: [target_account.id, target_account2.id]) } | ||||||
|  |  | ||||||
|  |         it 'suspends the expected users' do | ||||||
|  |           expect { subject }.to change { [target_account.reload.suspended?, target_account2.reload.suspended?] }.from([false, false]).to([true, true]) | ||||||
|  |         end | ||||||
|  |  | ||||||
|  |         it 'closes open reports targeting the suspended users' do | ||||||
|  |           expect { subject }.to change { Report.unresolved.where(target_account: [target_account, target_account2]).count }.from(2).to(0) | ||||||
|  |         end | ||||||
|  |       end | ||||||
|  |     end | ||||||
|  |   end | ||||||
|  | end | ||||||
		Reference in New Issue
	
	Block a user