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) }
|
|
|
|
|
let(:champ) { dossier.champs.first }
|
|
|
|
|
|
|
|
|
|
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
|
|
|
|
|
expect(champ.piece_justificative_file.filename).to eq('piece_justificative_0.pdf')
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it 'renders the attachment template as Javascript' do
|
|
|
|
|
subject
|
|
|
|
|
expect(response.status).to eq(200)
|
2022-07-26 11:03:31 +02:00
|
|
|
|
expect(response.body).to include(""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
|
|
|
|
|
end
|