forked from cybrespace/mastodon
		
	Add missing tests for admin/accounts_controller (#7791)
This commit is contained in:
		
							parent
							
								
									0979d4275a
								
							
						
					
					
						commit
						6151308c47
					
				
					 1 changed files with 219 additions and 5 deletions
				
			
		| 
						 | 
					@ -3,13 +3,11 @@ require 'rails_helper'
 | 
				
			||||||
RSpec.describe Admin::AccountsController, type: :controller do
 | 
					RSpec.describe Admin::AccountsController, type: :controller do
 | 
				
			||||||
  render_views
 | 
					  render_views
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  let(:user) { Fabricate(:user, admin: true) }
 | 
					  before { sign_in current_user, scope: :user }
 | 
				
			||||||
 | 
					 | 
				
			||||||
  before do
 | 
					 | 
				
			||||||
    sign_in user, scope: :user
 | 
					 | 
				
			||||||
  end
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  describe 'GET #index' do
 | 
					  describe 'GET #index' do
 | 
				
			||||||
 | 
					    let(:current_user) { Fabricate(:user, admin: true) }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    around do |example|
 | 
					    around do |example|
 | 
				
			||||||
      default_per_page = Account.default_per_page
 | 
					      default_per_page = Account.default_per_page
 | 
				
			||||||
      Account.paginates_per 1
 | 
					      Account.paginates_per 1
 | 
				
			||||||
| 
						 | 
					@ -68,6 +66,7 @@ RSpec.describe Admin::AccountsController, type: :controller do
 | 
				
			||||||
  end
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  describe 'GET #show' do
 | 
					  describe 'GET #show' do
 | 
				
			||||||
 | 
					    let(:current_user) { Fabricate(:user, admin: true) }
 | 
				
			||||||
    let(:account) { Fabricate(:account, username: 'bob') }
 | 
					    let(:account) { Fabricate(:account, username: 'bob') }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    it 'returns http success' do
 | 
					    it 'returns http success' do
 | 
				
			||||||
| 
						 | 
					@ -75,4 +74,219 @@ RSpec.describe Admin::AccountsController, type: :controller do
 | 
				
			||||||
      expect(response).to have_http_status(200)
 | 
					      expect(response).to have_http_status(200)
 | 
				
			||||||
    end
 | 
					    end
 | 
				
			||||||
  end
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  describe 'POST #subscribe' do
 | 
				
			||||||
 | 
					    subject { post :subscribe, params: { id: account.id } }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    let(:current_user) { Fabricate(:user, admin: admin) }
 | 
				
			||||||
 | 
					    let(:account) { Fabricate(:account) }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    context 'when user is admin' do
 | 
				
			||||||
 | 
					      let(:admin) { true }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      it { is_expected.to redirect_to admin_account_path(account.id) }
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    context 'when user is not admin' do
 | 
				
			||||||
 | 
					      let(:admin) { false }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      it { is_expected.to have_http_status :forbidden }
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  describe 'POST #unsubscribe' do
 | 
				
			||||||
 | 
					    subject { post :unsubscribe, params: { id: account.id } }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    let(:current_user) { Fabricate(:user, admin: admin) }
 | 
				
			||||||
 | 
					    let(:account) { Fabricate(:account) }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    context 'when user is admin' do
 | 
				
			||||||
 | 
					      let(:admin) { true }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      it { is_expected.to redirect_to admin_account_path(account.id) }
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    context 'when user is not admin' do
 | 
				
			||||||
 | 
					      let(:admin) { false }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      it { is_expected.to have_http_status :forbidden }
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  describe 'POST #memorialize' do
 | 
				
			||||||
 | 
					    subject { post :memorialize, params: { id: account.id } }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    let(:current_user) { Fabricate(:user, admin: current_user_admin) }
 | 
				
			||||||
 | 
					    let(:account) { Fabricate(:account, user: user) }
 | 
				
			||||||
 | 
					    let(:user) { Fabricate(:user, admin: target_user_admin) }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    context 'when user is admin' do
 | 
				
			||||||
 | 
					      let(:current_user_admin) { true }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      context 'when target user is admin' do
 | 
				
			||||||
 | 
					        let(:target_user_admin) { true }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        it 'fails to memorialize account' do
 | 
				
			||||||
 | 
					          is_expected.to have_http_status :forbidden
 | 
				
			||||||
 | 
					          expect(account.reload).not_to be_memorial
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      context 'when target user is not admin' do
 | 
				
			||||||
 | 
					        let(:target_user_admin) { false }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        it 'succeeds in memorializing account' do
 | 
				
			||||||
 | 
					          is_expected.to redirect_to admin_account_path(account.id)
 | 
				
			||||||
 | 
					          expect(account.reload).to be_memorial
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    context 'when user is not admin' do
 | 
				
			||||||
 | 
					      let(:current_user_admin) { false }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      context 'when target user is admin' do
 | 
				
			||||||
 | 
					        let(:target_user_admin) { true }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        it 'fails to memorialize account' do
 | 
				
			||||||
 | 
					          is_expected.to have_http_status :forbidden
 | 
				
			||||||
 | 
					          expect(account.reload).not_to be_memorial
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      context 'when target user is not admin' do
 | 
				
			||||||
 | 
					        let(:target_user_admin) { false }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        it 'fails to memorialize account' do
 | 
				
			||||||
 | 
					          is_expected.to have_http_status :forbidden
 | 
				
			||||||
 | 
					          expect(account.reload).not_to be_memorial
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  describe 'POST #enable' do
 | 
				
			||||||
 | 
					    subject { post :enable, params: { id: account.id } }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    let(:current_user) { Fabricate(:user, admin: admin) }
 | 
				
			||||||
 | 
					    let(:account) { Fabricate(:account, user: user) }
 | 
				
			||||||
 | 
					    let(:user) { Fabricate(:user, disabled: true) }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    context 'when user is admin' do
 | 
				
			||||||
 | 
					      let(:admin) { true }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      it 'succeeds in enabling account' do
 | 
				
			||||||
 | 
					        is_expected.to redirect_to admin_account_path(account.id)
 | 
				
			||||||
 | 
					        expect(user.reload).not_to be_disabled
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    context 'when user is not admin' do
 | 
				
			||||||
 | 
					      let(:admin) { false }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      it 'fails to enable account' do
 | 
				
			||||||
 | 
					        is_expected.to have_http_status :forbidden
 | 
				
			||||||
 | 
					        expect(user.reload).to be_disabled
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  describe 'POST #disable' do
 | 
				
			||||||
 | 
					    subject { post :disable, params: { id: account.id } }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    let(:current_user) { Fabricate(:user, admin: current_user_admin) }
 | 
				
			||||||
 | 
					    let(:account) { Fabricate(:account, user: user) }
 | 
				
			||||||
 | 
					    let(:user) { Fabricate(:user, disabled: false, admin: target_user_admin) }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    context 'when user is admin' do
 | 
				
			||||||
 | 
					      let(:current_user_admin) { true }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      context 'when target user is admin' do
 | 
				
			||||||
 | 
					        let(:target_user_admin) { true }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        it 'fails to disable account' do
 | 
				
			||||||
 | 
					          is_expected.to have_http_status :forbidden
 | 
				
			||||||
 | 
					          expect(user.reload).not_to be_disabled
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      context 'when target user is not admin' do
 | 
				
			||||||
 | 
					        let(:target_user_admin) { false }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        it 'succeeds in disabling account' do
 | 
				
			||||||
 | 
					          is_expected.to redirect_to admin_account_path(account.id)
 | 
				
			||||||
 | 
					          expect(user.reload).to be_disabled
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    context 'when user is not admin' do
 | 
				
			||||||
 | 
					      let(:current_user_admin) { false }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      context 'when target user is admin' do
 | 
				
			||||||
 | 
					        let(:target_user_admin) { true }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        it 'fails to disable account' do
 | 
				
			||||||
 | 
					          is_expected.to have_http_status :forbidden
 | 
				
			||||||
 | 
					          expect(user.reload).not_to be_disabled
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      context 'when target user is not admin' do
 | 
				
			||||||
 | 
					        let(:target_user_admin) { false }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        it 'fails to disable account' do
 | 
				
			||||||
 | 
					          is_expected.to have_http_status :forbidden
 | 
				
			||||||
 | 
					          expect(user.reload).not_to be_disabled
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  describe 'POST #redownload' do
 | 
				
			||||||
 | 
					    subject { post :redownload, params: { id: account.id } }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    let(:current_user) { Fabricate(:user, admin: admin) }
 | 
				
			||||||
 | 
					    let(:account) { Fabricate(:account) }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    context 'when user is admin' do
 | 
				
			||||||
 | 
					      let(:admin) { true }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      it 'succeeds in redownloadin' do
 | 
				
			||||||
 | 
					        is_expected.to redirect_to admin_account_path(account.id)
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    context 'when user is not admin' do
 | 
				
			||||||
 | 
					      let(:admin) { false }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      it 'fails to redownload' do
 | 
				
			||||||
 | 
					        is_expected.to have_http_status :forbidden
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  describe 'POST #remove_avatar' do
 | 
				
			||||||
 | 
					    subject { post :remove_avatar, params: { id: account.id } }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    let(:current_user) { Fabricate(:user, admin: admin) }
 | 
				
			||||||
 | 
					    let(:account) { Fabricate(:account) }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    context 'when user is admin' do
 | 
				
			||||||
 | 
					      let(:admin) { true }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      it 'succeeds in removing avatar' do
 | 
				
			||||||
 | 
					        is_expected.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
 | 
				
			||||||
 | 
					        is_expected.to have_http_status :forbidden
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		
		Reference in a new issue