mirror of
https://github.com/glitch-soc/mastodon.git
synced 2024-11-24 09:04:00 -05:00
9566893cc9
* Add render_views in more places * Delegate methods from account to user with allow nil true, so that admin accounts show view renders when missing a user * Use actual account instances in authorize follow controller spec
40 lines
1.2 KiB
Ruby
40 lines
1.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
|
|
describe MediaController do
|
|
render_views
|
|
|
|
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)
|
|
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(:missing)
|
|
end
|
|
|
|
it 'raises when shortcode cant be found' do
|
|
get :show, params: { id: 'missing' }
|
|
|
|
expect(response).to have_http_status(:missing)
|
|
end
|
|
|
|
it 'raises when not permitted to view' do
|
|
status = Fabricate(:status)
|
|
media_attachment = Fabricate(:media_attachment, status: status)
|
|
allow_any_instance_of(Status).to receive(:permitted?).and_return(false)
|
|
get :show, params: { id: media_attachment.to_param }
|
|
|
|
expect(response).to have_http_status(:missing)
|
|
end
|
|
end
|
|
end
|