demarches-normaliennes/spec/controllers/attachments_controller_spec.rb

91 lines
2.6 KiB
Ruby
Raw Normal View History

2019-05-29 12:05:28 +02:00
describe AttachmentsController, type: :controller do
let(:user) { create(:user) }
let(:attachment) { champ.piece_justificative_file.attachments.first }
let(:dossier) { create(:dossier, user: user) }
let(:champ) { create(:champ_piece_justificative, dossier_id: dossier.id) }
let(:signed_id) { attachment.blob.signed_id }
describe '#show' do
render_views
let(:format) { :turbo_stream }
subject do
request.headers['HTTP_REFERER'] = dossier_url(dossier)
get :show, params: { id: attachment.id, signed_id: signed_id }, format: format
end
context 'when authenticated' do
before { sign_in(user) }
context 'when requesting turbo_stream' do
let(:format) { :turbo_stream }
it { is_expected.to have_http_status(200) }
it 'renders turbo_stream that replaces the attachment HTML' do
subject
expect(response.body).to include(ActionView::RecordIdentifier.dom_id(attachment, :show))
end
end
context 'when the user opens the delete link in a new tab' do
let(:format) { :html }
it { is_expected.to have_http_status(302) }
it { is_expected.to redirect_to(dossier_path(dossier)) }
end
end
context 'when not authenticated' do
it { is_expected.to have_http_status(401) }
end
end
2019-05-29 12:05:28 +02:00
describe '#destroy' do
render_views
let(:attachment) { champ.piece_justificative_file.attachments.first }
2019-05-29 12:05:28 +02:00
let(:dossier) { create(:dossier, user: user) }
let(:champ) { create(:champ_piece_justificative, dossier_id: dossier.id) }
let(:signed_id) { attachment.blob.signed_id }
subject do
delete :destroy, params: { id: attachment.id, signed_id: signed_id }, format: :turbo_stream
2019-05-29 12:05:28 +02:00
end
context "when authenticated" do
before { sign_in(user) }
context 'and dossier is owned by user' do
it { is_expected.to have_http_status(200) }
it 'removes the attachment' do
2019-05-29 12:05:28 +02:00
subject
expect(champ.reload.piece_justificative_file.attached?).to be(false)
end
end
context 'and signed_id is invalid' do
let(:signed_id) { 'yolo' }
it { is_expected.to have_http_status(404) }
it 'doesnt remove the attachment' do
2019-05-29 12:05:28 +02:00
subject
expect(champ.reload.piece_justificative_file.attached?).to be(true)
end
end
end
context 'when not authenticated' do
it { is_expected.to have_http_status(401) }
it 'doesnt remove the attachment' do
2019-05-29 12:05:28 +02:00
subject
expect(champ.reload.piece_justificative_file.attached?).to be(true)
end
end
end
end