Add tests
This commit is contained in:
parent
349b708872
commit
46db6a6340
|
@ -6,33 +6,60 @@ describe MediaController do
|
||||||
render_views
|
render_views
|
||||||
|
|
||||||
describe '#show' do
|
describe '#show' do
|
||||||
it 'redirects to the file url when attached to a status' do
|
|
||||||
status = Fabricate(:status)
|
|
||||||
media_attachment = Fabricate(:media_attachment, status: status, shortcode: 'foo')
|
|
||||||
get :show, params: { id: media_attachment.to_param }
|
|
||||||
|
|
||||||
expect(response).to redirect_to(media_attachment.file.url(:original))
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'responds with missing when there is not an attached status' do
|
|
||||||
media_attachment = Fabricate(:media_attachment, status: nil, shortcode: 'foo')
|
|
||||||
get :show, params: { id: media_attachment.to_param }
|
|
||||||
|
|
||||||
expect(response).to have_http_status(404)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'raises when shortcode cant be found' do
|
it 'raises when shortcode cant be found' do
|
||||||
get :show, params: { id: 'missing' }
|
get :show, params: { id: 'missing' }
|
||||||
|
|
||||||
expect(response).to have_http_status(404)
|
expect(response).to have_http_status(404)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'raises when not permitted to view' do
|
context 'when the media attachment has a shortcode' do
|
||||||
status = Fabricate(:status, visibility: :direct)
|
it 'redirects to the file url when attached to a status' do
|
||||||
media_attachment = Fabricate(:media_attachment, status: status, shortcode: 'foo')
|
status = Fabricate(:status)
|
||||||
get :show, params: { id: media_attachment.to_param }
|
media_attachment = Fabricate(:media_attachment, status: status, shortcode: 'foo')
|
||||||
|
get :show, params: { id: media_attachment.to_param }
|
||||||
|
|
||||||
expect(response).to have_http_status(404)
|
expect(response).to redirect_to(media_attachment.file.url(:original))
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'responds with missing when there is not an attached status' do
|
||||||
|
media_attachment = Fabricate(:media_attachment, status: nil, shortcode: 'foo')
|
||||||
|
get :show, params: { id: media_attachment.to_param }
|
||||||
|
|
||||||
|
expect(response).to have_http_status(404)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'raises when not permitted to view' do
|
||||||
|
status = Fabricate(:status, visibility: :direct)
|
||||||
|
media_attachment = Fabricate(:media_attachment, status: status, shortcode: 'foo')
|
||||||
|
get :show, params: { id: media_attachment.to_param }
|
||||||
|
|
||||||
|
expect(response).to have_http_status(404)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'when the media attachment has no shortcode' do
|
||||||
|
it 'redirects to the file url when attached to a status' do
|
||||||
|
status = Fabricate(:status)
|
||||||
|
media_attachment = Fabricate(:media_attachment, status: status)
|
||||||
|
get :show, params: { id: media_attachment.to_param }
|
||||||
|
|
||||||
|
expect(response).to redirect_to(media_attachment.file.url(:original))
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'responds with missing when there is not an attached status' do
|
||||||
|
media_attachment = Fabricate(:media_attachment, status: nil)
|
||||||
|
get :show, params: { id: media_attachment.to_param }
|
||||||
|
|
||||||
|
expect(response).to have_http_status(404)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'raises when not permitted to view' do
|
||||||
|
status = Fabricate(:status, visibility: :direct)
|
||||||
|
media_attachment = Fabricate(:media_attachment, status: status)
|
||||||
|
get :show, params: { id: media_attachment.to_param }
|
||||||
|
|
||||||
|
expect(response).to have_http_status(404)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Reference in New Issue