Convert statuses#activity action controller to request spec (#33336)
		
	This commit is contained in:
		
					parent
					
						
							
								0085e8c427
							
						
					
				
			
			
				commit
				
					
						d65e246192
					
				
			
		
					 2 changed files with 218 additions and 209 deletions
				
			
		|  | @ -527,213 +527,4 @@ RSpec.describe StatusesController do | |||
|       end | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   describe 'GET #activity' do | ||||
|     let(:account) { Fabricate(:account) } | ||||
|     let(:status)  { Fabricate(:status, account: account) } | ||||
| 
 | ||||
|     context 'when account is permanently suspended' do | ||||
|       before do | ||||
|         account.suspend! | ||||
|         account.deletion_request.destroy | ||||
| 
 | ||||
|         get :activity, params: { account_username: account.username, id: status.id } | ||||
|       end | ||||
| 
 | ||||
|       it 'returns http gone' do | ||||
|         expect(response).to have_http_status(410) | ||||
|       end | ||||
|     end | ||||
| 
 | ||||
|     context 'when account is temporarily suspended' do | ||||
|       before do | ||||
|         account.suspend! | ||||
| 
 | ||||
|         get :activity, params: { account_username: account.username, id: status.id } | ||||
|       end | ||||
| 
 | ||||
|       it 'returns http forbidden' do | ||||
|         expect(response).to have_http_status(403) | ||||
|       end | ||||
|     end | ||||
| 
 | ||||
|     context 'when status is public' do | ||||
|       before do | ||||
|         status.update(visibility: :public) | ||||
|         get :activity, params: { account_username: account.username, id: status.id } | ||||
|       end | ||||
| 
 | ||||
|       it 'returns http success' do | ||||
|         expect(response).to have_http_status(:success) | ||||
|       end | ||||
|     end | ||||
| 
 | ||||
|     context 'when status is private' do | ||||
|       before do | ||||
|         status.update(visibility: :private) | ||||
|         get :activity, params: { account_username: account.username, id: status.id } | ||||
|       end | ||||
| 
 | ||||
|       it 'returns http not_found' do | ||||
|         expect(response).to have_http_status(404) | ||||
|       end | ||||
|     end | ||||
| 
 | ||||
|     context 'when status is direct' do | ||||
|       before do | ||||
|         status.update(visibility: :direct) | ||||
|         get :activity, params: { account_username: account.username, id: status.id } | ||||
|       end | ||||
| 
 | ||||
|       it 'returns http not_found' do | ||||
|         expect(response).to have_http_status(404) | ||||
|       end | ||||
|     end | ||||
| 
 | ||||
|     context 'when signed-in' do | ||||
|       let(:user) { Fabricate(:user) } | ||||
| 
 | ||||
|       before do | ||||
|         sign_in(user) | ||||
|       end | ||||
| 
 | ||||
|       context 'when status is public' do | ||||
|         before do | ||||
|           status.update(visibility: :public) | ||||
|           get :activity, params: { account_username: account.username, id: status.id } | ||||
|         end | ||||
| 
 | ||||
|         it 'returns http success' do | ||||
|           expect(response).to have_http_status(:success) | ||||
|         end | ||||
|       end | ||||
| 
 | ||||
|       context 'when status is private' do | ||||
|         before do | ||||
|           status.update(visibility: :private) | ||||
|         end | ||||
| 
 | ||||
|         context 'when user is authorized to see it' do | ||||
|           before do | ||||
|             user.account.follow!(account) | ||||
|             get :activity, params: { account_username: account.username, id: status.id } | ||||
|           end | ||||
| 
 | ||||
|           it 'returns http success' do | ||||
|             expect(response).to have_http_status(200) | ||||
|           end | ||||
|         end | ||||
| 
 | ||||
|         context 'when user is not authorized to see it' do | ||||
|           before do | ||||
|             get :activity, params: { account_username: account.username, id: status.id } | ||||
|           end | ||||
| 
 | ||||
|           it 'returns http not_found' do | ||||
|             expect(response).to have_http_status(404) | ||||
|           end | ||||
|         end | ||||
|       end | ||||
| 
 | ||||
|       context 'when status is direct' do | ||||
|         before do | ||||
|           status.update(visibility: :direct) | ||||
|         end | ||||
| 
 | ||||
|         context 'when user is authorized to see it' do | ||||
|           before do | ||||
|             Fabricate(:mention, account: user.account, status: status) | ||||
|             get :activity, params: { account_username: account.username, id: status.id } | ||||
|           end | ||||
| 
 | ||||
|           it 'returns http success' do | ||||
|             expect(response).to have_http_status(200) | ||||
|           end | ||||
|         end | ||||
| 
 | ||||
|         context 'when user is not authorized to see it' do | ||||
|           before do | ||||
|             get :activity, params: { account_username: account.username, id: status.id } | ||||
|           end | ||||
| 
 | ||||
|           it 'returns http not_found' do | ||||
|             expect(response).to have_http_status(404) | ||||
|           end | ||||
|         end | ||||
|       end | ||||
|     end | ||||
| 
 | ||||
|     context 'with signature' do | ||||
|       let(:remote_account) { Fabricate(:account, domain: 'example.com') } | ||||
| 
 | ||||
|       before do | ||||
|         allow(controller).to receive(:signed_request_actor).and_return(remote_account) | ||||
|       end | ||||
| 
 | ||||
|       context 'when status is public' do | ||||
|         before do | ||||
|           status.update(visibility: :public) | ||||
|           get :activity, params: { account_username: account.username, id: status.id } | ||||
|         end | ||||
| 
 | ||||
|         it 'returns http success' do | ||||
|           expect(response).to have_http_status(:success) | ||||
|         end | ||||
|       end | ||||
| 
 | ||||
|       context 'when status is private' do | ||||
|         before do | ||||
|           status.update(visibility: :private) | ||||
|         end | ||||
| 
 | ||||
|         context 'when user is authorized to see it' do | ||||
|           before do | ||||
|             remote_account.follow!(account) | ||||
|             get :activity, params: { account_username: account.username, id: status.id } | ||||
|           end | ||||
| 
 | ||||
|           it 'returns http success' do | ||||
|             expect(response).to have_http_status(200) | ||||
|           end | ||||
|         end | ||||
| 
 | ||||
|         context 'when user is not authorized to see it' do | ||||
|           before do | ||||
|             get :activity, params: { account_username: account.username, id: status.id } | ||||
|           end | ||||
| 
 | ||||
|           it 'returns http not_found' do | ||||
|             expect(response).to have_http_status(404) | ||||
|           end | ||||
|         end | ||||
|       end | ||||
| 
 | ||||
|       context 'when status is direct' do | ||||
|         before do | ||||
|           status.update(visibility: :direct) | ||||
|         end | ||||
| 
 | ||||
|         context 'when user is authorized to see it' do | ||||
|           before do | ||||
|             Fabricate(:mention, account: remote_account, status: status) | ||||
|             get :activity, params: { account_username: account.username, id: status.id } | ||||
|           end | ||||
| 
 | ||||
|           it 'returns http success' do | ||||
|             expect(response).to have_http_status(200) | ||||
|           end | ||||
|         end | ||||
| 
 | ||||
|         context 'when user is not authorized to see it' do | ||||
|           before do | ||||
|             get :activity, params: { account_username: account.username, id: status.id } | ||||
|           end | ||||
| 
 | ||||
|           it 'returns http not_found' do | ||||
|             expect(response).to have_http_status(404) | ||||
|           end | ||||
|         end | ||||
|       end | ||||
|     end | ||||
|   end | ||||
| end | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue