fix(fork): don't let active storage override our champ#updated_at after a transaction
This commit is contained in:
parent
9b52f0902d
commit
0d21450f8a
2 changed files with 27 additions and 3 deletions
|
@ -108,12 +108,15 @@ module DossierCloneConcern
|
|||
transaction do
|
||||
cloned_dossier.save!
|
||||
|
||||
if fork
|
||||
cloned_dossier.rebase!
|
||||
end
|
||||
end
|
||||
|
||||
if fork
|
||||
cloned_champs.values.each do |(original, champ)|
|
||||
champ.update_columns(created_at: original.created_at, updated_at: original.updated_at)
|
||||
end
|
||||
cloned_dossier.rebase!
|
||||
end
|
||||
end
|
||||
|
||||
cloned_dossier.reload
|
||||
|
|
|
@ -162,6 +162,27 @@ RSpec.describe DossierCloneConcern do
|
|||
end
|
||||
end
|
||||
end
|
||||
|
||||
context "as a fork" do
|
||||
let(:new_dossier) { dossier.clone(fork: true) }
|
||||
|
||||
it { expect(new_dossier.editing_fork_origin).to eq(dossier) }
|
||||
it { expect(new_dossier.champs_public[0].id).not_to eq(dossier.champs_public[0].id) }
|
||||
it { expect(new_dossier.champs_public[0].created_at).to eq(dossier.champs_public[0].created_at) }
|
||||
it { expect(new_dossier.champs_public[0].updated_at).to eq(dossier.champs_public[0].updated_at) }
|
||||
|
||||
context "piece justificative champ" do
|
||||
let(:champ_pj) { create(:champ_piece_justificative, dossier_id: dossier.id) }
|
||||
before { dossier.champs_public << champ_pj }
|
||||
|
||||
it {
|
||||
champ_pj_fork = Champs::PieceJustificativeChamp.where(dossier: new_dossier).first
|
||||
expect(champ_pj_fork.piece_justificative_file.first.blob).to eq(champ_pj.piece_justificative_file.first.blob)
|
||||
expect(champ_pj_fork.created_at).to eq(champ_pj.created_at)
|
||||
expect(champ_pj_fork.updated_at).to eq(champ_pj.updated_at)
|
||||
}
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
describe '#make_diff' do
|
||||
|
|
Loading…
Reference in a new issue