Merge pull request #7242 from betagouv/main

2022-05-04-02
This commit is contained in:
LeSim 2022-05-04 13:35:38 +02:00 committed by GitHub
commit d6f392827b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 21 additions and 38 deletions

View file

@ -714,7 +714,7 @@ class Procedure < ApplicationRecord
def create_new_revision def create_new_revision
draft_revision draft_revision
.deep_clone(include: [:revision_types_de_champ_public, :revision_types_de_champ_private]) .deep_clone(include: [:revision_types_de_champ])
.tap(&:save!) .tap(&:save!)
end end

View file

@ -18,8 +18,10 @@ class ProcedureRevision < ApplicationRecord
has_many :dossiers, inverse_of: :revision, foreign_key: :revision_id has_many :dossiers, inverse_of: :revision, foreign_key: :revision_id
has_many :revision_types_de_champ, class_name: 'ProcedureRevisionTypeDeChamp', foreign_key: :revision_id, dependent: :destroy, inverse_of: :revision
has_many :revision_types_de_champ_public, -> { root.public_only.ordered }, class_name: 'ProcedureRevisionTypeDeChamp', foreign_key: :revision_id, dependent: :destroy, inverse_of: :revision has_many :revision_types_de_champ_public, -> { root.public_only.ordered }, class_name: 'ProcedureRevisionTypeDeChamp', foreign_key: :revision_id, dependent: :destroy, inverse_of: :revision
has_many :revision_types_de_champ_private, -> { root.private_only.ordered }, class_name: 'ProcedureRevisionTypeDeChamp', foreign_key: :revision_id, dependent: :destroy, inverse_of: :revision has_many :revision_types_de_champ_private, -> { root.private_only.ordered }, class_name: 'ProcedureRevisionTypeDeChamp', foreign_key: :revision_id, dependent: :destroy, inverse_of: :revision
has_many :types_de_champ, through: :revision_types_de_champ, source: :type_de_champ
has_many :types_de_champ_public, through: :revision_types_de_champ_public, source: :type_de_champ has_many :types_de_champ_public, through: :revision_types_de_champ_public, source: :type_de_champ
has_many :types_de_champ_private, through: :revision_types_de_champ_private, source: :type_de_champ has_many :types_de_champ_private, through: :revision_types_de_champ_private, source: :type_de_champ
@ -46,10 +48,8 @@ class ProcedureRevision < ApplicationRecord
.tap do |types_de_champ| .tap do |types_de_champ|
params[:order_place] = types_de_champ.present? ? types_de_champ.last.order_place + 1 : 0 params[:order_place] = types_de_champ.present? ? types_de_champ.last.order_place + 1 : 0
end.create(params).migrate_parent! end.create(params).migrate_parent!
elsif params[:private]
types_de_champ_private.create(params)
else else
types_de_champ_public.create(params) types_de_champ.create(params)
end end
end end
@ -76,13 +76,11 @@ class ProcedureRevision < ApplicationRecord
type_de_champ.update!(order_place: position) type_de_champ.update!(order_place: position)
type_de_champ.revision_type_de_champ&.update!(position: position) type_de_champ.revision_type_de_champ&.update!(position: position)
end end
elsif type_de_champ.private?
move_type_de_champ_hash(types_de_champ_private.to_a, type_de_champ, position).each do |(id, position)|
revision_types_de_champ_private.find_by!(type_de_champ_id: id).update!(position: position)
end
else else
move_type_de_champ_hash(types_de_champ_public.to_a, type_de_champ, position).each do |(id, position)| liste = type_de_champ.private? ? types_de_champ_private : types_de_champ_public
revision_types_de_champ_public.find_by!(type_de_champ_id: id).update!(position: position)
move_type_de_champ_hash(liste.to_a, type_de_champ, position).each do |(id, position)|
revision_types_de_champ.find_by!(type_de_champ_id: id).update!(position: position)
end end
end end
end end
@ -94,10 +92,8 @@ class ProcedureRevision < ApplicationRecord
type_de_champ.destroy type_de_champ.destroy
elsif type_de_champ.parent.present? elsif type_de_champ.parent.present?
find_or_clone_type_de_champ(id).destroy find_or_clone_type_de_champ(id).destroy
elsif type_de_champ.private?
types_de_champ_private.delete(type_de_champ)
else else
types_de_champ_public.delete(type_de_champ) types_de_champ.delete(type_de_champ)
end end
end end
@ -110,8 +106,7 @@ class ProcedureRevision < ApplicationRecord
end end
def different_from?(revision) def different_from?(revision)
types_de_champ_public != revision.types_de_champ_public || types_de_champ != revision.types_de_champ ||
types_de_champ_private != revision.types_de_champ_private ||
attestation_template != revision.attestation_template attestation_template != revision.attestation_template
end end
@ -390,13 +385,12 @@ class ProcedureRevision < ApplicationRecord
end end
def find_type_de_champ_by_id(id) def find_type_de_champ_by_id(id)
types_de_champ_public.find_by(stable_id: id) || types_de_champ.find_by(stable_id: id) ||
types_de_champ_private.find_by(stable_id: id) ||
types_de_champ_in_repetition.find_by!(stable_id: id) types_de_champ_in_repetition.find_by!(stable_id: id)
end end
def types_de_champ_in_repetition def types_de_champ_in_repetition
parent_ids = types_de_champ_public.repetition.ids + types_de_champ_private.repetition.ids parent_ids = types_de_champ.repetition.ids
TypeDeChamp.where(parent_id: parent_ids) TypeDeChamp.where(parent_id: parent_ids)
end end

View file

@ -5,7 +5,7 @@ describe ProcedurePresentation do
context 'for a draft procedure' do context 'for a draft procedure' do
let(:procedure) { create(:procedure) } let(:procedure) { create(:procedure) }
context 'when there are one tdc on a published revision' do context 'when there are one tdc on a draft revision' do
let!(:tdc) { { type_champ: :number, libelle: 'libelle 1' } } let!(:tdc) { { type_champ: :number, libelle: 'libelle 1' } }
before { procedure.draft_revision.add_type_de_champ(tdc) } before { procedure.draft_revision.add_type_de_champ(tdc) }
@ -37,26 +37,26 @@ describe ProcedurePresentation do
end end
context 'add one tdc above the first one' do context 'add one tdc above the first one' do
let(:tdc2) { { type_champ: :number, libelle: 'libelle 2' } } let(:tdc0) { { type_champ: :number, libelle: 'libelle 0' } }
before do before do
created_tdc2 = procedure.draft_revision.add_type_de_champ(tdc2) created_tdc0 = procedure.draft_revision.add_type_de_champ(tdc0)
procedure.draft_revision.move_type_de_champ(created_tdc2.stable_id, 0) procedure.draft_revision.move_type_de_champ(created_tdc0.stable_id, 0)
procedure.publish_revision! procedure.publish_revision!
end end
it { is_expected.to match(['libelle 2', 'libelle 1']) } it { is_expected.to match(['libelle 0', 'libelle 1']) }
context 'and finally, when this tdc is removed' do context 'and finally, when this tdc is removed' do
let!(:previous_tdc2) { procedure.published_revision.types_de_champ_public.find_by(libelle: 'libelle 2') } let!(:previous_tdc0) { procedure.published_revision.types_de_champ_public.find_by(libelle: 'libelle 0') }
before do before do
procedure.draft_revision.remove_type_de_champ(previous_tdc2.stable_id) procedure.draft_revision.remove_type_de_champ(previous_tdc0.stable_id)
procedure.publish_revision! procedure.publish_revision!
end end
it { is_expected.to match(['libelle 1', 'libelle 2']) } it { is_expected.to match(['libelle 1', 'libelle 0']) }
end end
end end
@ -73,18 +73,6 @@ describe ProcedurePresentation do
it { is_expected.to match(['changed libelle 1']) } it { is_expected.to match(['changed libelle 1']) }
end end
context 'when there is another published which removes a previous tdc' do
let!(:previous_tdc) { procedure.published_revision.types_de_champ_public.first }
before do
type_de_champ = procedure.draft_revision.remove_type_de_champ(previous_tdc.id)
procedure.publish_revision!
end
it { is_expected.to match(['libelle 1']) }
end
end end
end end
end end

View file

@ -164,6 +164,7 @@ describe ProcedureRevision do
libelle: "Un champ text" libelle: "Un champ text"
}) })
revision.reload revision.reload
new_revision.reload
expect(new_revision.types_de_champ_public.size).to eq(3) expect(new_revision.types_de_champ_public.size).to eq(3)
expect(new_revision.types_de_champ_public.last).to eq(new_type_de_champ) expect(new_revision.types_de_champ_public.last).to eq(new_type_de_champ)
expect(new_revision.revision_types_de_champ_public.last.position).to eq(2) expect(new_revision.revision_types_de_champ_public.last.position).to eq(2)