migrate test for `GET /api/v1/accounts/{account_id}` to request spec (#25322)
This commit is contained in:
		
							parent
							
								
									99216e34e5
								
							
						
					
					
						commit
						b19a695608
					
				|  | @ -55,20 +55,6 @@ RSpec.describe Api::V1::AccountsController do | |||
|     end | ||||
|   end | ||||
| 
 | ||||
|   describe 'GET #show' do | ||||
|     let(:scopes) { 'read:accounts' } | ||||
| 
 | ||||
|     before do | ||||
|       get :show, params: { id: user.account.id } | ||||
|     end | ||||
| 
 | ||||
|     it 'returns http success' do | ||||
|       expect(response).to have_http_status(200) | ||||
|     end | ||||
| 
 | ||||
|     it_behaves_like 'forbidden for wrong scope', 'write:statuses' | ||||
|   end | ||||
| 
 | ||||
|   describe 'POST #follow' do | ||||
|     let(:scopes) { 'write:follows' } | ||||
|     let(:other_account) { Fabricate(:account, username: 'bob', locked: locked) } | ||||
|  |  | |||
|  | @ -0,0 +1,53 @@ | |||
| # frozen_string_literal: true | ||||
| 
 | ||||
| require 'rails_helper' | ||||
| 
 | ||||
| describe 'GET /api/v1/accounts/{account_id}' do | ||||
|   it 'returns account entity as 200 OK' do | ||||
|     account = Fabricate(:account) | ||||
| 
 | ||||
|     get "/api/v1/accounts/#{account.id}" | ||||
| 
 | ||||
|     aggregate_failures do | ||||
|       expect(response).to have_http_status(200) | ||||
|       expect(body_as_json[:id]).to eq(account.id.to_s) | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   it 'returns 404 if account not found' do | ||||
|     get '/api/v1/accounts/1' | ||||
| 
 | ||||
|     aggregate_failures do | ||||
|       expect(response).to have_http_status(404) | ||||
|       expect(body_as_json[:error]).to eq('Record not found') | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   context 'when with token' do | ||||
|     it 'returns account entity as 200 OK if token is valid' do | ||||
|       account = Fabricate(:account) | ||||
|       user = Fabricate(:user, account: account) | ||||
|       token = Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: 'read:accounts').token | ||||
| 
 | ||||
|       get "/api/v1/accounts/#{account.id}", headers: { Authorization: "Bearer #{token}" } | ||||
| 
 | ||||
|       aggregate_failures do | ||||
|         expect(response).to have_http_status(200) | ||||
|         expect(body_as_json[:id]).to eq(account.id.to_s) | ||||
|       end | ||||
|     end | ||||
| 
 | ||||
|     it 'returns 403 if scope of token is invalid' do | ||||
|       account = Fabricate(:account) | ||||
|       user = Fabricate(:user, account: account) | ||||
|       token = Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: 'write:statuses').token | ||||
| 
 | ||||
|       get "/api/v1/accounts/#{account.id}", headers: { Authorization: "Bearer #{token}" } | ||||
| 
 | ||||
|       aggregate_failures do | ||||
|         expect(response).to have_http_status(403) | ||||
|         expect(body_as_json[:error]).to eq('This action is outside the authorized scopes') | ||||
|       end | ||||
|     end | ||||
|   end | ||||
| end | ||||
		Loading…
	
		Reference in New Issue