]> git.openstreetmap.org Git - rails.git/blobdiff - test/factories/node.rb
Merge remote-tracking branch 'upstream/pull/5419'
[rails.git] / test / factories / node.rb
index 697a5c1ae43a84915106b8d44d1dbc46c2fa6018..bfb8b16fe79d48abe310f59fad5db06d4c5cf0c7 100644 (file)
@@ -1,13 +1,31 @@
-FactoryGirl.define do
+FactoryBot.define do
   factory :node do
-    latitude 1 * GeoRecord::SCALE
-    longitude 1 * GeoRecord::SCALE
+    latitude { 1 * GeoRecord::SCALE }
+    longitude { 1 * GeoRecord::SCALE }
 
-    # FIXME: needs changeset factory
-    changeset_id 1
+    changeset
 
-    visible true
-    timestamp Time.now
-    version 1
+    visible { true }
+    timestamp { Time.now.utc }
+    version { 1 }
+
+    trait :deleted do
+      visible { false }
+    end
+
+    trait :with_history do
+      after(:create) do |node, _evaluator|
+        (1..node.version).each do |n|
+          create(:old_node, :node_id => node.id, :version => n, :latitude => node.latitude, :longitude => node.longitude, :changeset => node.changeset)
+        end
+
+        # For deleted nodes, make sure the most recent old_node is also deleted.
+        if node.visible == false
+          latest = node.old_nodes.find_by(:version => node.version)
+          latest.visible = false
+          latest.save
+        end
+      end
+    end
   end
 end