demarches-normaliennes/spec/controllers/attachments_controller_spec.rb

90 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(:procedure) { create(:procedure, types_de_champ_public: [{ type: :piece_justificative }]) }
let(:dossier) { create(:dossier, :with_populated_champs, user:, procedure:) }
let(:champ) { dossier.champs.first }
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 redirect_to(new_user_session_path) }
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(:signed_id) { attachment.blob.signed_id }
subject do
delete :destroy, params: { id: attachment.id, signed_id: signed_id, dossier_id: dossier.id, stable_id: champ.stable_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 redirect_to(new_user_session_path) }
2019-05-29 12:05:28 +02:00
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