Merge pull request #3059 from tchak/type_de_champ_key
Type de champ stable API ids
This commit is contained in:
commit
034b3f600b
8 changed files with 55 additions and 0 deletions
|
@ -199,6 +199,7 @@ class Procedure < ApplicationRecord
|
||||||
end
|
end
|
||||||
|
|
||||||
def clone(admin, from_library)
|
def clone(admin, from_library)
|
||||||
|
populate_champ_stable_ids
|
||||||
procedure = self.deep_clone(include:
|
procedure = self.deep_clone(include:
|
||||||
{
|
{
|
||||||
types_de_piece_justificative: nil,
|
types_de_piece_justificative: nil,
|
||||||
|
@ -358,6 +359,12 @@ class Procedure < ApplicationRecord
|
||||||
gestionnaire || gestionnaires.first
|
gestionnaire || gestionnaires.first
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def populate_champ_stable_ids
|
||||||
|
TypeDeChamp.where(procedure: self, stable_id: nil).find_each do |type_de_champ|
|
||||||
|
type_de_champ.update_column(:stable_id, type_de_champ.id)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def claim_path_ownership!(path)
|
def claim_path_ownership!(path)
|
||||||
|
|
|
@ -36,6 +36,7 @@ class TypeDeChamp < ApplicationRecord
|
||||||
store :options, accessors: [:cadastres, :quartiers_prioritaires, :parcelles_agricoles]
|
store :options, accessors: [:cadastres, :quartiers_prioritaires, :parcelles_agricoles]
|
||||||
|
|
||||||
after_initialize :set_dynamic_type
|
after_initialize :set_dynamic_type
|
||||||
|
after_create :populate_stable_id
|
||||||
|
|
||||||
attr_reader :dynamic_type
|
attr_reader :dynamic_type
|
||||||
|
|
||||||
|
@ -117,6 +118,12 @@ class TypeDeChamp < ApplicationRecord
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
|
def populate_stable_id
|
||||||
|
if !stable_id
|
||||||
|
update_column(:stable_id, id)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def remove_piece_justificative_template
|
def remove_piece_justificative_template
|
||||||
if type_champ != TypeDeChamp.type_champs.fetch(:piece_justificative) && piece_justificative_template.attached?
|
if type_champ != TypeDeChamp.type_champs.fetch(:piece_justificative) && piece_justificative_template.attached?
|
||||||
piece_justificative_template.purge_later
|
piece_justificative_template.purge_later
|
||||||
|
|
|
@ -4,4 +4,8 @@ class TypeDeChampSerializer < ActiveModel::Serializer
|
||||||
:type_champ,
|
:type_champ,
|
||||||
:order_place,
|
:order_place,
|
||||||
:description
|
:description
|
||||||
|
|
||||||
|
def id
|
||||||
|
object.stable_id || object.id
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -0,0 +1,6 @@
|
||||||
|
class AddStableIdToTypesDeChamp < ActiveRecord::Migration[5.2]
|
||||||
|
def change
|
||||||
|
add_column :types_de_champ, :stable_id, :bigint
|
||||||
|
add_index :types_de_champ, :stable_id
|
||||||
|
end
|
||||||
|
end
|
|
@ -556,7 +556,9 @@ ActiveRecord::Schema.define(version: 2018_11_23_195208) do
|
||||||
t.datetime "created_at"
|
t.datetime "created_at"
|
||||||
t.datetime "updated_at"
|
t.datetime "updated_at"
|
||||||
t.jsonb "options"
|
t.jsonb "options"
|
||||||
|
t.bigint "stable_id"
|
||||||
t.index ["private"], name: "index_types_de_champ_on_private"
|
t.index ["private"], name: "index_types_de_champ_on_private"
|
||||||
|
t.index ["stable_id"], name: "index_types_de_champ_on_stable_id"
|
||||||
end
|
end
|
||||||
|
|
||||||
create_table "types_de_piece_justificative", id: :serial, force: :cascade do |t|
|
create_table "types_de_piece_justificative", id: :serial, force: :cascade do |t|
|
||||||
|
|
|
@ -0,0 +1,15 @@
|
||||||
|
namespace :after_party do
|
||||||
|
desc 'Deployment task: add_stable_id_to_types_de_champ'
|
||||||
|
task add_stable_id_to_types_de_champ: :environment do
|
||||||
|
types_de_champ = TypeDeChamp.where(stable_id: nil)
|
||||||
|
bar = RakeProgressbar.new(types_de_champ.count)
|
||||||
|
|
||||||
|
types_de_champ.find_each do |type_de_champ|
|
||||||
|
type_de_champ.update_column(:stable_id, type_de_champ.id)
|
||||||
|
bar.inc
|
||||||
|
end
|
||||||
|
bar.finished
|
||||||
|
|
||||||
|
AfterParty::TaskRecord.create version: '20181123181252'
|
||||||
|
end
|
||||||
|
end
|
|
@ -424,6 +424,11 @@ describe Procedure do
|
||||||
expect(subject.path).to be_nil
|
expect(subject.path).to be_nil
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it 'should keep types_de_champ ids stable' do
|
||||||
|
expect(subject.types_de_champ_ordered.first.id).not_to eq(procedure.types_de_champ_ordered.first.id)
|
||||||
|
expect(subject.types_de_champ_ordered.first.stable_id).to eq(procedure.types_de_champ_ordered.first.id)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe '#publish!' do
|
describe '#publish!' do
|
||||||
|
|
|
@ -39,6 +39,15 @@ shared_examples 'type_de_champ_spec' do
|
||||||
it { is_expected.to allow_value('blabla').for(:description) }
|
it { is_expected.to allow_value('blabla').for(:description) }
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context 'stable_id' do
|
||||||
|
it {
|
||||||
|
type_de_champ = create(:type_de_champ_text)
|
||||||
|
expect(type_de_champ.id).to eq(type_de_champ.stable_id)
|
||||||
|
cloned_type_de_champ = type_de_champ.clone
|
||||||
|
expect(cloned_type_de_champ.stable_id).to eq(type_de_champ.stable_id)
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
context 'remove piece_justificative_template' do
|
context 'remove piece_justificative_template' do
|
||||||
context 'when the tdc is piece_justificative' do
|
context 'when the tdc is piece_justificative' do
|
||||||
let(:template_double) { double('template', attached?: attached, purge_later: true) }
|
let(:template_double) { double('template', attached?: attached, purge_later: true) }
|
||||||
|
|
Loading…
Add table
Reference in a new issue