Convert `disputes/appeals` spec controller->system (#33434)

pull/2926/head
Matt Jankowski 2025-01-02 11:08:25 -05:00 committed by GitHub
parent 1fbd106af9
commit 8e3fd1b823
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 53 additions and 47 deletions

View File

@ -1,47 +0,0 @@
# frozen_string_literal: true
require 'rails_helper'
RSpec.describe Disputes::AppealsController do
render_views
before { sign_in current_user, scope: :user }
let!(:admin) { Fabricate(:user, role: UserRole.find_by(name: 'Admin')) }
describe '#create' do
subject { post :create, params: params }
context 'with valid params' do
let(:current_user) { Fabricate(:user) }
let(:strike) { Fabricate(:account_warning, target_account: current_user.account) }
let(:params) { { strike_id: strike.id, appeal: { text: 'Foo' } } }
it 'notifies staff about new appeal and redirects back to strike page', :inline_jobs do
emails = capture_emails { subject }
expect(emails.size)
.to eq(1)
expect(emails.first)
.to have_attributes(
to: contain_exactly(admin.email),
subject: eq(I18n.t('admin_mailer.new_appeal.subject', username: current_user.account.acct, instance: Rails.configuration.x.local_domain))
)
expect(response).to redirect_to(disputes_strike_path(strike.id))
end
end
context 'with invalid params' do
let(:current_user) { Fabricate(:user) }
let(:strike) { Fabricate(:account_warning, target_account: current_user.account) }
let(:params) { { strike_id: strike.id, appeal: { text: '' } } }
it 'does not send email and renders strike show page', :inline_jobs do
emails = capture_emails { subject }
expect(emails).to be_empty
expect(response).to render_template('disputes/strikes/show')
end
end
end
end

View File

@ -0,0 +1,53 @@
# frozen_string_literal: true
require 'rails_helper'
RSpec.describe 'Dispute Appeals' do
let(:user) { Fabricate(:user) }
let!(:admin) { Fabricate(:user, role: UserRole.find_by(name: 'Admin')) }
before { sign_in user }
describe 'Submitting an appeal', :inline_jobs do
let(:strike) { Fabricate(:account_warning, target_account: user.account) }
it 'Submits the appeal and notifies admins' do
visit disputes_strike_path(strike)
# Invalid with missing attribute
fill_in 'appeal_text', with: ''
emails = capture_emails do
expect { submit_form }
.to_not change(Appeal, :count)
end
expect(emails)
.to be_empty
expect(page)
.to have_content(/can't be blank/)
# Valid with text
fill_in 'appeal_text', with: 'It wasnt me this time!'
emails = capture_emails do
expect { submit_form }
.to change(Appeal, :count).by(1)
end
expect(emails)
.to contain_exactly(
have_attributes(
to: contain_exactly(admin.email),
subject: eq(new_appeal_subject)
)
)
expect(page)
.to have_content(I18n.t('disputes.strikes.appealed_msg'))
end
def new_appeal_subject
I18n.t('admin_mailer.new_appeal.subject', username: user.account.acct, instance: Rails.configuration.x.local_domain)
end
def submit_form
click_on I18n.t('disputes.strikes.appeals.submit')
end
end
end