gearheads
/
mastodon
Archived
2
0
Fork 0

Add tests for account_moderation_notes_controller (#7524)

gh/stable
Shuhei Kitagawa 2018-05-17 11:26:51 +09:00 committed by Eugen Rochko
parent dfb6907e08
commit b48a166c82
1 changed files with 42 additions and 0 deletions

View File

@ -1,4 +1,46 @@
require 'rails_helper' require 'rails_helper'
RSpec.describe Admin::AccountModerationNotesController, type: :controller do RSpec.describe Admin::AccountModerationNotesController, type: :controller do
render_views
let(:user) { Fabricate(:user, admin: true) }
let(:target_account) { Fabricate(:account) }
before do
sign_in user, scope: :user
end
describe 'POST #create' do
subject { post :create, params: params }
context 'when parameters are valid' do
let(:params) { { account_moderation_note: { target_account_id: target_account.id, content: 'test content' } } }
it 'successfully creates a note' do
expect { subject }.to change { AccountModerationNote.count }.by(1)
expect(subject).to redirect_to admin_account_path(target_account.id)
end
end
context 'when parameters are invalid' do
let(:params) { { account_moderation_note: { target_account_id: target_account.id, content: '' } } }
it 'falls to create a note' do
expect { subject }.not_to change { AccountModerationNote.count }
expect(subject).to render_template 'admin/accounts/show'
end
end
end
describe 'DELETE #destroy' do
subject { delete :destroy, params: { id: note.id } }
let!(:note) { Fabricate(:account_moderation_note, account: account, target_account: target_account) }
let(:account) { Fabricate(:account) }
it 'destroys note' do
expect { subject }.to change { AccountModerationNote.count }.by(-1)
expect(subject).to redirect_to admin_account_path(target_account.id)
end
end
end end