X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/2cf4ea4fe0e1eda66d510983bf27fb9836af5ff4..1f82ade9be8494e114156210d600a9624262ddba:/services/api/test/unit/collection_test.rb diff --git a/services/api/test/unit/collection_test.rb b/services/api/test/unit/collection_test.rb index e8cd21a243..addea83062 100644 --- a/services/api/test/unit/collection_test.rb +++ b/services/api/test/unit/collection_test.rb @@ -1000,6 +1000,19 @@ class CollectionTest < ActiveSupport::TestCase test "delete referring links in SweepTrashedObjects" do uuid = collections(:trashed_on_next_sweep).uuid act_as_system_user do + assert_raises ActiveRecord::RecordInvalid do + # Cannot create because :trashed_on_next_sweep is already trashed + Link.create!(head_uuid: uuid, + tail_uuid: system_user_uuid, + link_class: 'whatever', + name: 'something') + end + + # Bump trash_at to now + 1 minute + Collection.where(uuid: uuid). + update(trash_at: db_current_time + (1).minute) + + # Not considered trashed now Link.create!(head_uuid: uuid, tail_uuid: system_user_uuid, link_class: 'whatever', @@ -1013,10 +1026,27 @@ class CollectionTest < ActiveSupport::TestCase assert_empty Collection.where(uuid: uuid) end - test "create collections with default properties" do - Rails.configuration.Collections.DefaultProperties = { - 'default_prop1' => {'value' => 'prop1_value'}, - 'responsible_person_uuid' => {'function' => 'original_owner'} + test "empty names are exempt from name uniqueness" do + act_as_user users(:active) do + c1 = Collection.new(name: nil, manifest_text: '', owner_uuid: groups(:aproject).uuid) + assert c1.save + c2 = Collection.new(name: '', manifest_text: '', owner_uuid: groups(:aproject).uuid) + assert c2.save + c3 = Collection.new(name: '', manifest_text: '', owner_uuid: groups(:aproject).uuid) + assert c3.save + c4 = Collection.new(name: 'c4', manifest_text: '', owner_uuid: groups(:aproject).uuid) + assert c4.save + c5 = Collection.new(name: 'c4', manifest_text: '', owner_uuid: groups(:aproject).uuid) + assert_raises(ActiveRecord::RecordNotUnique) do + c5.save + end + end + end + + test "create collections with managed properties" do + Rails.configuration.Collections.ManagedProperties = { + 'default_prop1' => {'Value' => 'prop1_value'}, + 'responsible_person_uuid' => {'Function' => 'original_owner'} } # Test collection without initial properties act_as_user users(:active) do @@ -1045,9 +1075,9 @@ class CollectionTest < ActiveSupport::TestCase end end - test "update collection with protected default properties" do - Rails.configuration.Collections.DefaultProperties = { - 'default_prop1' => {'value' => 'prop1_value', 'protected' => true}, + test "update collection with protected managed properties" do + Rails.configuration.Collections.ManagedProperties = { + 'default_prop1' => {'Value' => 'prop1_value', 'Protected' => true}, } act_as_user users(:active) do c = create_collection 'foo', Encoding::US_ASCII @@ -1057,6 +1087,7 @@ class CollectionTest < ActiveSupport::TestCase # Add new property c.properties['prop2'] = 'value2' c.save! + c.reload assert_equal 'value2', c.properties['prop2'] # Try to change protected property's value c.properties['default_prop1'] = 'new_value' @@ -1067,8 +1098,30 @@ class CollectionTest < ActiveSupport::TestCase act_as_system_user do c.properties['default_prop1'] = 'new_value' c.save! + c.reload assert_equal 'new_value', c.properties['default_prop1'] end end end + + test "collection names must be displayable in a filesystem" do + set_user_from_auth :active + ["", "{SOLIDUS}"].each do |subst| + Rails.configuration.Collections.ForwardSlashNameSubstitution = subst + c = Collection.create + [[nil, true], + ["", true], + [".", false], + ["..", false], + ["...", true], + ["..z..", true], + ["foo/bar", subst != ""], + ["../..", subst != ""], + ["/", subst != ""], + ].each do |name, valid| + c.name = name + assert_equal valid, c.valid?, "#{name.inspect} should be #{valid ? "valid" : "invalid"}" + end + end + end end