refs #4926 #5072 Merge branch '4926-fix-imagesizes'
[arvados.git] / services / api / test / unit / collection_test.rb
index 9253dddbe07c72f23aae56301cfa349c14115d86..1386a25e749d99026527d58fe9c5cda82f232bc5 100644 (file)
@@ -45,33 +45,49 @@ class CollectionTest < ActiveSupport::TestCase
       assert c.valid?
       created_file_names = c.file_names
       assert created_file_names
+      assert_match /foo.txt/, c.file_names
 
       c.update_attribute 'manifest_text', ". d41d8cd98f00b204e9800998ecf8427e+0 0:0:foo2.txt\n"
       assert_not_equal created_file_names, c.file_names
+      assert_match /foo2.txt/, c.file_names
     end
   end
 
   [
-    2**8,
-    2**18,
-  ].each do |manifest_size|
-    test "create collection with manifest size #{manifest_size} and
-          not expect exceptions even on very large manifest texts" do
+    [2**8, false],
+    [2**18, true],
+  ].each do |manifest_size, gets_truncated|
+    test "create collection with manifest size #{manifest_size} which gets truncated #{gets_truncated},
+          and not expect exceptions even on very large manifest texts" do
       # file_names has a max size, hence there will be no errors even on large manifests
       act_as_system_user do
-        manifest_text = '. d41d8cd98f00b204e9800998ecf8427e+0'
+        manifest_text = './blurfl d41d8cd98f00b204e9800998ecf8427e+0'
         index = 0
         while manifest_text.length < manifest_size
-          manifest_text += ' ' + "0:0:longlongfile#{index}.txt"
+          manifest_text += ' ' + "0:0:veryverylongfilename000000000000#{index}.txt\n./subdir1"
           index += 1
         end
         manifest_text += "\n"
-
         c = Collection.create(manifest_text: manifest_text)
 
         assert c.valid?
-        created_file_names = c.file_names
-        assert created_file_names
+        assert c.file_names
+        assert_match /veryverylongfilename0000000000001.txt/, c.file_names
+        assert_match /veryverylongfilename0000000000002.txt/, c.file_names
+        if !gets_truncated
+          assert_match /blurfl/, c.file_names
+          assert_match /subdir1/, c.file_names
+        end
+      end
+    end
+  end
+
+  [0, 2, 4, nil].each do |ask|
+    test "replication_desired reports #{ask or 2} if redundancy is #{ask}" do
+      act_as_user users(:active) do
+        c = collections(:collection_owned_by_active)
+        c.update_attributes redundancy: ask
+        assert_equal (ask or 2), c.replication_desired
       end
     end
   end