aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorZog2018-01-11 12:16:38 +0100
committerZog2018-01-11 12:16:38 +0100
commit833d1e4f991f0f7a0f8800bbdc97410a846ffcec (patch)
treebbaed9e86151b76d294622e5849dadd6132f8eff
parent25ddf5946b9e0e5412e6e0db5f0b6be264b59a72 (diff)
downloadchouette-core-833d1e4f991f0f7a0f8800bbdc97410a846ffcec.tar.bz2
Refs #5547 @0.25h; Show newly created VJ's short_id in editor
-rw-r--r--app/models/chouette/vehicle_journey.rb4
-rw-r--r--spec/models/chouette/vehicle_journey_spec.rb6
2 files changed, 8 insertions, 2 deletions
diff --git a/app/models/chouette/vehicle_journey.rb b/app/models/chouette/vehicle_journey.rb
index 11da77948..11e489ab2 100644
--- a/app/models/chouette/vehicle_journey.rb
+++ b/app/models/chouette/vehicle_journey.rb
@@ -195,7 +195,9 @@ module Chouette
def self.state_create_instance route, item
# Flag new record, so we can unset object_id if transaction rollback
vj = route.vehicle_journeys.create(state_permited_attributes(item))
- item['objectid'] = vj.objectid
+ vj.after_commit_objectid
+ item['objectid'] = vj.objectid
+ item['short_id'] = vj.get_objectid.short_id
item['new_record'] = true
vj
end
diff --git a/spec/models/chouette/vehicle_journey_spec.rb b/spec/models/chouette/vehicle_journey_spec.rb
index 3ec2387e5..06cac6bc7 100644
--- a/spec/models/chouette/vehicle_journey_spec.rb
+++ b/spec/models/chouette/vehicle_journey_spec.rb
@@ -100,11 +100,15 @@ describe Chouette::VehicleJourney, :type => :model do
Chouette::VehicleJourney.state_update(route, collection)
}.to change {Chouette::VehicleJourney.count}.by(1)
- expect(collection.last['objectid']).not_to be_nil
obj = Chouette::VehicleJourney.last
+ expect(obj).to receive(:after_commit_objectid).and_call_original
+
+ # For some reason we have to force it
+ obj.after_commit_objectid
obj.run_callbacks(:commit)
+ expect(collection.last['objectid']).to eq obj.objectid
expect(obj.published_journey_name).to eq 'dummy'
end