4523: add tests to search for file name
authorRadhika Chippada <radhika@curoverse.com>
Wed, 7 Jan 2015 17:59:26 +0000 (12:59 -0500)
committerRadhika Chippada <radhika@curoverse.com>
Wed, 7 Jan 2015 17:59:26 +0000 (12:59 -0500)
services/api/app/models/collection.rb
services/api/db/migrate/20141208174653_collection_file_names.rb
services/api/db/structure.sql
services/api/test/integration/collections_api_test.rb
services/api/test/unit/collection_test.rb

index 20170604cd01b66c32345f229c0218ef27f16305..6c5e1acc4e3f8af86f537bcea2698b998fe7d4ae 100644 (file)
@@ -136,7 +136,7 @@ class Collection < ArvadosModel
           file_names << file_name if file_name != '.'
         end
       end
-      self.file_names = file_names.uniq.join(" ")[0,2**12]
+      self.file_names = file_names.uniq.join(" ")[0,2**13]
     end
     true
   end
index dc2158402e91835098646c9276d40bcdb2aeb346..8cccbba1923e566d47a119cfd19516437222e525 100644 (file)
@@ -2,7 +2,7 @@ class CollectionFileNames < ActiveRecord::Migration
   include CurrentApiClient
 
   def up
-    add_column :collections, :file_names, :string, :limit => 2**12
+    add_column :collections, :file_names, :string, :limit => 2**13
 
     act_as_system_user do
       Collection.all.each do |c|
@@ -13,7 +13,7 @@ class CollectionFileNames < ActiveRecord::Migration
             file_names << file_name if file_name != '.'
           end
 
-          c.file_names = file_names.uniq.join(" ")[0,2**12]
+          c.file_names = file_names.uniq.join(" ")[0,2**13]
           c.save!
         end
       end
index 047a90145aac85bb14af53b90877deb13301a2ab..df3e58fe9a2400ea87730060d0cdbe4a74c71613 100644 (file)
@@ -170,7 +170,7 @@ CREATE TABLE collections (
     description character varying(524288),
     properties text,
     expires_at date,
-    file_names character varying(4096)
+    file_names character varying(8192)
 );
 
 
index 76805922bebcf08649a54efc516f613dfbb6089d..40b19fe66cf3eafec5f51d8c4490458db0fbf7c9 100644 (file)
@@ -133,5 +133,63 @@ class CollectionsApiTest < ActionDispatch::IntegrationTest
     assert_equal 'a name', json_response['name']
   end
 
+  test "create collection, verify file_names not returned, and search with filename" do
+    signing_opts = {
+      key: Rails.configuration.blob_signing_key,
+      api_token: api_token(:active),
+    }
+    signed_locator = Blob.sign_locator('bad42fa702ae3ea7d999fef11b46f450+44', signing_opts)
 
+    post "/arvados/v1/collections", {
+      format: :json,
+      collection: "{\"manifest_text\":\". #{signed_locator} 0:44:my_test_file.txt\\n\"}"
+    }, auth(:active)
+    assert_response 200
+    assert_equal '0f99f4087beb13dec46d36db9fa6cebf+60', json_response['portable_data_hash']
+    assert_nil json_response['description']
+    assert_nil json_response['file_names']
+
+    put "/arvados/v1/collections/#{json_response['uuid']}", {
+      format: :json,
+      collection: { description: "my test collection description" }
+    }, auth(:active)
+    assert_response :success
+    assert_equal 'my test collection description', json_response['description']
+    assert_equal '0f99f4087beb13dec46d36db9fa6cebf+60', json_response['portable_data_hash']
+    assert_nil json_response['file_names']
+
+    get '/arvados/v1/collections', {
+      where: { any: ['contains', '87beb13dec46d36db9fa'] }
+    }, auth(:active)
+    assert_response :success
+    response_items = json_response['items']
+    assert_not_nil response_items
+    first_item = json_response['items'].first
+    assert_not_nil first_item
+    assert_equal 'my test collection description', first_item['description']
+    assert_equal '0f99f4087beb13dec46d36db9fa6cebf+60', first_item['portable_data_hash']
+    assert_nil first_item['file_names']
+
+    get '/arvados/v1/collections', {
+      where: { any: ['contains', 'my_test_file.txt'] }
+    }, auth(:active)
+    assert_response :success
+    response_items = json_response['items']
+    assert_not_nil response_items
+    assert_equal 1, response_items.size
+    first_item = response_items.first
+    assert_not_nil first_item
+    assert_equal 'my test collection description', first_item['description']
+    assert_equal '0f99f4087beb13dec46d36db9fa6cebf+60', first_item['portable_data_hash']
+    assert_nil first_item['file_names']
+
+    get '/arvados/v1/collections', {
+      where: { any: ['contains', 'there_is_no_such_file.txt'] }
+    }, auth(:active)
+    assert_response :success
+    assert_equal 0, json_response['items_available']
+    response_items = json_response['items']
+    assert_not_nil response_items
+    assert_equal 0, response_items.size
+  end
 end
index 1a5eee94c9ccfe6149d0f8b3a446150a2f3542ea..ed257a745b4895fab557c20829128d177d2238ad 100644 (file)
@@ -51,21 +51,45 @@ class CollectionTest < ActiveSupport::TestCase
     end
   end
 
-  test 'create collection with large manifest text and verify file_names' do
-    act_as_system_user do
-      manifest_text = ". d41d8cd98f00b204e9800998ecf8427e+0"
-      index = 0
-      while manifest_text.length < 2**15
-        manifest_text += ' ' + "0:0:foo#{index}.txt"
-        index += 1
-      end
-      manifest_text += "\n"
+  [
+    [2**15, 0, false],
+    [2**15, 100, false],
+    [2**15, 2**13, false],
+    [2**15, 2**18, true],
+    [100, 2**18, true],
+    [2**18, 100, false],  # file_names has a max size, hence no error even on large manifest
+  ].each do |manifest_size, description_size, expect_exception|
+    test "create collection with manifest size #{manifest_size},
+          description size #{description_size},
+          expect exception #{expect_exception}" do
+      act_as_system_user do
+        manifest_text = '. d41d8cd98f00b204e9800998ecf8427e+0'
+        index = 0
+        while manifest_text.length < manifest_size
+          manifest_text += ' ' + "0:0:longlongfile#{index}.txt"
+          index += 1
+        end
+        manifest_text += "\n"
 
-      c = Collection.create(manifest_text: manifest_text)
+        description = ''
+        while description.length < description_size
+          description += 'a'
+        end
 
-      assert c.valid?
-      created_file_names = c.file_names
-      assert created_file_names
+        begin
+          c = Collection.create(manifest_text: manifest_text, description: description)
+        rescue Exception => e
+        end
+
+        if !expect_exception
+          assert c.valid?
+          created_file_names = c.file_names
+          assert created_file_names
+        else
+          assert e
+          assert e.message.include? 'exceeds maximum'
+        end
+      end
     end
   end