18005: Exposes the bug by simulating a keep-balance run a making a new version.
authorLucas Di Pentima <lucas.dipentima@curii.com>
Wed, 11 Aug 2021 18:31:11 +0000 (15:31 -0300)
committerLucas Di Pentima <lucas.dipentima@curii.com>
Wed, 11 Aug 2021 18:31:11 +0000 (15:31 -0300)
Arvados-DCO-1.1-Signed-off-by: Lucas Di Pentima <lucas.dipentima@curii.com>

services/api/test/unit/collection_test.rb

index e6912217d53fa5b484be8597ae6280465eda8ae5..8b8edbc15319fe7cc9f9aee0c21d46aa3cb23506 100644 (file)
@@ -185,6 +185,23 @@ class CollectionTest < ActiveSupport::TestCase
       c.reload
       assert_equal 'foobar', c.name
       assert_equal 2, c.version
+      # Simulate a keep-balance run and trigger a new versionable update
+      # This tests bug #18005
+      assert_nil c.replication_confirmed
+      assert_nil c.replication_confirmed_at
+      # Updates without validations/callbacks
+      c.update_column('modified_at', fifteen_min_ago)
+      c.update_column('replication_confirmed_at', Time.now)
+      c.update_column('replication_confirmed', 2)
+      c.reload
+      assert_equal fifteen_min_ago.to_i, c.modified_at.to_i
+      assert_not_nil c.replication_confirmed_at
+      assert_not_nil c.replication_confirmed
+      # Make the versionable update
+      c.update_attributes!({'name' => 'foobarbaz'})
+      c.reload
+      assert_equal 'foobarbaz', c.name
+      assert_equal 3, c.version
     end
   end