diff options
author | Claire <claire.github-309c@sitedethib.com> | 2021-12-18 11:44:54 +0100 |
---|---|---|
committer | Claire <claire.github-309c@sitedethib.com> | 2021-12-18 11:44:54 +0100 |
commit | d4f315f3044f69dfe64fbfd2348fcaa5deb2aa5e (patch) | |
tree | e3684038c30aef2dd3a0c9b5ec76de83e043663c /spec/controllers/admin/accounts_controller_spec.rb | |
parent | 7efef7db9ed6f7b25a28166c1b75a28adbaf7cdb (diff) | |
parent | 76761d5fc0886e44a7a6eb94ab62aae8204d9e6e (diff) |
Merge branch 'main' into glitch-soc/merge-upstream
Diffstat (limited to 'spec/controllers/admin/accounts_controller_spec.rb')
-rw-r--r-- | spec/controllers/admin/accounts_controller_spec.rb | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/spec/controllers/admin/accounts_controller_spec.rb b/spec/controllers/admin/accounts_controller_spec.rb index a5ef396ae..3edbde03c 100644 --- a/spec/controllers/admin/accounts_controller_spec.rb +++ b/spec/controllers/admin/accounts_controller_spec.rb @@ -192,4 +192,36 @@ RSpec.describe Admin::AccountsController, type: :controller do end end end + + describe 'POST #unblock_email' do + subject do + -> { post :unblock_email, params: { id: account.id } } + end + + let(:current_user) { Fabricate(:user, admin: admin) } + let(:account) { Fabricate(:account, suspended: true) } + let!(:email_block) { Fabricate(:canonical_email_block, reference_account: account) } + + context 'when user is admin' do + let(:admin) { true } + + it 'succeeds in removing email blocks' do + is_expected.to change { CanonicalEmailBlock.where(reference_account: account).count }.from(1).to(0) + end + + it 'redirects to admin account path' do + subject.call + expect(response).to redirect_to admin_account_path(account.id) + end + end + + context 'when user is not admin' do + let(:admin) { false } + + it 'fails to remove avatar' do + subject.call + expect(response).to have_http_status :forbidden + end + end + end end |