2023-10-16 16:45:08 +02:00
|
|
|
describe DataFixer::DossierChampsMissing do
|
|
|
|
describe '#fix' do
|
2024-01-23 09:52:20 +01:00
|
|
|
let(:procedure) { create(:procedure, types_de_champ_public: [{ type: :datetime }, { type: :dossier_link }]) }
|
2023-10-16 16:45:08 +02:00
|
|
|
let(:dossier) { create(:dossier, procedure:) }
|
|
|
|
|
|
|
|
context 'when dossier does not have a fork' do
|
|
|
|
before { dossier.champs_public.first.destroy }
|
|
|
|
subject { described_class.new(dossier:).fix }
|
|
|
|
|
|
|
|
it 'add missing champs to the dossier' do
|
|
|
|
expect { subject }.to change { dossier.champs_public.count }.from(1).to(2)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns number of added champs' do
|
|
|
|
expect(subject).to eq(1)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when dossier have a fork' do
|
|
|
|
before { dossier.champs_public.first.destroy }
|
|
|
|
let(:create_fork) { dossier.find_or_create_editing_fork(dossier.user) }
|
|
|
|
subject do
|
|
|
|
create_fork
|
|
|
|
described_class.new(dossier:).fix
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'add missing champs to the fork too' do
|
|
|
|
expect { subject }.to change { create_fork.champs_public.count }.from(1).to(2)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'sums number of added champs for dossier and editing_fork_origin_id' do
|
|
|
|
expect(subject).to eq(2)
|
|
|
|
end
|
|
|
|
end
|
2023-10-17 17:44:07 +02:00
|
|
|
|
|
|
|
context 'when dossier have missing champ on repetition' do
|
2024-01-23 09:52:20 +01:00
|
|
|
let(:procedure) { create(:procedure, types_de_champ_public: [{ type: :repetition, children: [{ type: :text }, { type: :decimal_number }] }]) }
|
2023-10-17 17:44:07 +02:00
|
|
|
let(:dossier) { create(:dossier, :with_populated_champs, procedure:) }
|
|
|
|
let(:champ_repetition) { dossier.champs_public.first }
|
|
|
|
let(:initial_champ_count) { dossier.champs.count }
|
|
|
|
before do
|
|
|
|
initial_champ_count
|
|
|
|
champ_repetition.champs.first.destroy
|
|
|
|
end
|
|
|
|
subject { described_class.new(dossier:).fix }
|
|
|
|
|
|
|
|
it 'add missing champs to repetition' do
|
|
|
|
expect { subject }.to change { dossier.champs.count }.from(initial_champ_count - 1).to(initial_champ_count)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'counts number of added champs for dossier.repetitions' do
|
|
|
|
expect(subject).to eq(1)
|
|
|
|
end
|
|
|
|
end
|
2023-10-16 16:45:08 +02:00
|
|
|
end
|
|
|
|
end
|