diff options
author | Andrew Tomaka <atomaka@gmail.com> | 2015-12-02 07:40:24 +0300 |
---|---|---|
committer | Andrew Tomaka <atomaka@gmail.com> | 2015-12-02 16:07:29 +0300 |
commit | daca985a6e75d6f43c5cc5b487a0942d5bf93f68 (patch) | |
tree | 579e8734014953e8aaa1c784cd4a857e50c6ed79 /spec | |
parent | 09e712c0fb721059e4b2619eb9fc104257fc492d (diff) |
Prevent impersonation if blocked
Diffstat (limited to 'spec')
-rw-r--r-- | spec/controllers/admin/impersonation_controller_spec.rb | 19 | ||||
-rw-r--r-- | spec/features/admin/admin_users_spec.rb | 10 |
2 files changed, 29 insertions, 0 deletions
diff --git a/spec/controllers/admin/impersonation_controller_spec.rb b/spec/controllers/admin/impersonation_controller_spec.rb new file mode 100644 index 00000000000..d7a7ba1c5b6 --- /dev/null +++ b/spec/controllers/admin/impersonation_controller_spec.rb @@ -0,0 +1,19 @@ +require 'spec_helper' + +describe Admin::ImpersonationController do + let(:admin) { create(:admin) } + + before do + sign_in(admin) + end + + describe 'CREATE #impersonation when blocked' do + let(:blocked_user) { create(:user, state: :blocked) } + + it 'does not allow impersonation' do + post :create, id: blocked_user.username + + expect(flash[:alert]).to eq 'You cannot impersonate a blocked user' + end + end +end diff --git a/spec/features/admin/admin_users_spec.rb b/spec/features/admin/admin_users_spec.rb index 86f01faffb4..4570e409128 100644 --- a/spec/features/admin/admin_users_spec.rb +++ b/spec/features/admin/admin_users_spec.rb @@ -128,6 +128,16 @@ describe "Admin::Users", feature: true do expect(page).not_to have_content('Impersonate') end + + it 'should not show impersonate button for blocked user' do + another_user.block + + visit admin_user_path(another_user) + + expect(page).not_to have_content('Impersonate') + + another_user.activate + end end context 'when impersonating' do |