2020-03-30 15:34:56 +02:00
|
|
|
|
describe Champs::PieceJustificativeController, type: :controller do
|
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
|
let(:procedure) { create(:procedure, :published, :with_piece_justificative) }
|
|
|
|
|
let(:dossier) { create(:dossier, user: user, procedure: procedure) }
|
2022-11-10 22:21:14 +01:00
|
|
|
|
let(:champ) { dossier.champs_public.first }
|
2020-03-30 15:34:56 +02:00
|
|
|
|
|
|
|
|
|
describe '#update' do
|
|
|
|
|
render_views
|
|
|
|
|
before { sign_in user }
|
|
|
|
|
|
|
|
|
|
subject do
|
|
|
|
|
put :update, params: {
|
|
|
|
|
position: '1',
|
|
|
|
|
champ_id: champ.id,
|
|
|
|
|
blob_signed_id: file
|
2022-05-06 19:52:55 +02:00
|
|
|
|
}, format: :turbo_stream
|
2020-03-30 15:34:56 +02:00
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context 'when the file is valid' do
|
2020-06-30 17:53:54 +02:00
|
|
|
|
let(:file) { fixture_file_upload('spec/fixtures/files/piece_justificative_0.pdf', 'application/pdf') }
|
2020-03-30 15:34:56 +02:00
|
|
|
|
|
|
|
|
|
it 'attach the file' do
|
|
|
|
|
subject
|
|
|
|
|
champ.reload
|
|
|
|
|
expect(champ.piece_justificative_file.attached?).to be true
|
2022-10-29 16:08:59 +02:00
|
|
|
|
expect(champ.piece_justificative_file[0].filename).to eq('piece_justificative_0.pdf')
|
2020-03-30 15:34:56 +02:00
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it 'renders the attachment template as Javascript' do
|
|
|
|
|
subject
|
|
|
|
|
expect(response.status).to eq(200)
|
2022-10-11 23:39:26 +02:00
|
|
|
|
expect(response.body).to include("<turbo-stream action=\"morph\" target=\"#{champ.input_group_id}\">")
|
2020-03-30 15:34:56 +02:00
|
|
|
|
end
|
2022-01-05 18:02:43 +01:00
|
|
|
|
|
|
|
|
|
it 'updates dossier.last_champ_updated_at' do
|
|
|
|
|
expect { subject }.to change { dossier.reload.last_champ_updated_at }
|
|
|
|
|
end
|
2020-03-30 15:34:56 +02:00
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context 'when the file is invalid' do
|
2020-06-30 17:53:54 +02:00
|
|
|
|
let(:file) { fixture_file_upload('spec/fixtures/files/invalid_file_format.json', 'application/json') }
|
2020-03-30 15:34:56 +02:00
|
|
|
|
|
|
|
|
|
# TODO: for now there are no validators on the champ piece_justificative_file,
|
|
|
|
|
# so we have to mock a failing validation.
|
|
|
|
|
# Once the validators will be enabled, remove those mocks, and let the usual
|
|
|
|
|
# validation fail naturally.
|
|
|
|
|
#
|
|
|
|
|
# See https://github.com/betagouv/demarches-simplifiees.fr/issues/4926
|
|
|
|
|
before do
|
|
|
|
|
champ
|
2020-06-24 17:25:32 +02:00
|
|
|
|
expect_any_instance_of(Champs::PieceJustificativeChamp).to receive(:save).twice.and_return(false)
|
2020-03-30 15:34:56 +02:00
|
|
|
|
expect_any_instance_of(Champs::PieceJustificativeChamp).to receive(:errors)
|
|
|
|
|
.and_return(double(full_messages: ['La pièce justificative n’est pas d’un type accepté']))
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it 'doesn’t attach the file' do
|
|
|
|
|
subject
|
|
|
|
|
expect(champ.reload.piece_justificative_file.attached?).to be false
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it 'renders an error' do
|
|
|
|
|
subject
|
|
|
|
|
expect(response.status).to eq(422)
|
|
|
|
|
expect(response.header['Content-Type']).to include('application/json')
|
|
|
|
|
expect(JSON.parse(response.body)).to eq({ 'errors' => ['La pièce justificative n’est pas d’un type accepté'] })
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
2022-12-01 17:57:53 +01:00
|
|
|
|
|
|
|
|
|
describe '#template' do
|
|
|
|
|
before { Timecop.freeze }
|
|
|
|
|
after { Timecop.return }
|
|
|
|
|
|
|
|
|
|
subject do
|
|
|
|
|
get :template, params: {
|
|
|
|
|
champ_id: champ.id
|
|
|
|
|
}
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "user signed in" do
|
|
|
|
|
before { sign_in user }
|
|
|
|
|
|
|
|
|
|
it 'redirects to the template' do
|
|
|
|
|
subject
|
|
|
|
|
expect(response).to redirect_to(champ.type_de_champ.piece_justificative_template.blob)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "another user signed in" do
|
|
|
|
|
before { sign_in create(:user) }
|
|
|
|
|
|
|
|
|
|
it "should not share template url" do
|
|
|
|
|
expect { subject }.to raise_error(ActiveRecord::RecordNotFound)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "user anonymous" do
|
|
|
|
|
it 'does not redirect to the template' do
|
|
|
|
|
subject
|
|
|
|
|
expect(response).to redirect_to(new_user_session_path)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
2020-03-30 15:34:56 +02:00
|
|
|
|
end
|