mirror of
https://github.com/mastodon/mastodon.git
synced 2025-01-07 19:05:08 +01:00
Convert disputes/appeals
spec controller->system (#33434)
This commit is contained in:
parent
1fbd106af9
commit
8e3fd1b823
@ -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
|
|
53
spec/system/disputes/appeals_spec.rb
Normal file
53
spec/system/disputes/appeals_spec.rb
Normal 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
|
Loading…
Reference in New Issue
Block a user