Cover Api::V1:FavouritesController more (#4409)
This commit is contained in:
		
							parent
							
								
									b7d47c2aef
								
							
						
					
					
						commit
						0f92119ceb
					
				@ -6,16 +6,74 @@ RSpec.describe Api::V1::FavouritesController, type: :controller do
 | 
				
			|||||||
  let(:user)  { Fabricate(:user) }
 | 
					  let(:user)  { Fabricate(:user) }
 | 
				
			||||||
  let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: 'read') }
 | 
					  let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: 'read') }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  before do
 | 
					 | 
				
			||||||
    Fabricate(:favourite, account: user.account)
 | 
					 | 
				
			||||||
    allow(controller).to receive(:doorkeeper_token) { token }
 | 
					 | 
				
			||||||
  end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  describe 'GET #index' do
 | 
					  describe 'GET #index' do
 | 
				
			||||||
    it 'returns http success' do
 | 
					    context 'without token' do
 | 
				
			||||||
      get :index, params: { limit: 1 }
 | 
					      it 'returns http unauthorized' do
 | 
				
			||||||
 | 
					        get :index
 | 
				
			||||||
 | 
					        expect(response).to have_http_status :unauthorized
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      expect(response).to have_http_status(:success)
 | 
					    context 'with token' do
 | 
				
			||||||
 | 
					      context 'without read scope' do
 | 
				
			||||||
 | 
					        before do
 | 
				
			||||||
 | 
					          allow(controller).to receive(:doorkeeper_token) do
 | 
				
			||||||
 | 
					            Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: '')
 | 
				
			||||||
 | 
					          end
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        it 'returns http forbidden' do
 | 
				
			||||||
 | 
					          get :index
 | 
				
			||||||
 | 
					          expect(response).to have_http_status :forbidden
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      context 'without valid resource owner' do
 | 
				
			||||||
 | 
					        before do
 | 
				
			||||||
 | 
					          token = Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: 'read')
 | 
				
			||||||
 | 
					          user.destroy!
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          allow(controller).to receive(:doorkeeper_token) { token }
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        it 'returns http unprocessable entity' do
 | 
				
			||||||
 | 
					          get :index
 | 
				
			||||||
 | 
					          expect(response).to have_http_status :unprocessable_entity
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      context 'with read scope and valid resource owner' do
 | 
				
			||||||
 | 
					        before do
 | 
				
			||||||
 | 
					          allow(controller).to receive(:doorkeeper_token) do
 | 
				
			||||||
 | 
					            Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: 'read')
 | 
				
			||||||
 | 
					          end
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        it 'shows favourites owned by the user' do
 | 
				
			||||||
 | 
					          favourite_by_user = Fabricate(:favourite, account: user.account)
 | 
				
			||||||
 | 
					          favourite_by_others = Fabricate(:favourite)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          get :index
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          expect(assigns(:statuses)).to match_array [favourite_by_user.status]
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        it 'adds pagination headers if necessary' do
 | 
				
			||||||
 | 
					          favourite = Fabricate(:favourite, account: user.account)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          get :index, params: { limit: 1 }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          expect(response.headers['Link'].find_link(['rel', 'next']).href).to eq "http://test.host/api/v1/favourites?limit=1&max_id=#{favourite.id}"
 | 
				
			||||||
 | 
					          expect(response.headers['Link'].find_link(['rel', 'prev']).href).to eq "http://test.host/api/v1/favourites?limit=1&since_id=#{favourite.id}"
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        it 'does not add pagination headers if not necessary' do
 | 
				
			||||||
 | 
					          get :index
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          expect(response.headers['Link'].find_link(['rel', 'next'])).to eq nil
 | 
				
			||||||
 | 
					          expect(response.headers['Link'].find_link(['rel', 'prev'])).to eq nil
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
    end
 | 
					    end
 | 
				
			||||||
  end
 | 
					  end
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user