X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/eff37344f3cecd5aed259c9852aca4bdcdfb6922..516685e09227ab64c2d4f7fd04d4b60a75fc5d0f:/services/api/test/integration/collections_api_test.rb diff --git a/services/api/test/integration/collections_api_test.rb b/services/api/test/integration/collections_api_test.rb index 4251047cea..ac1ca66376 100644 --- a/services/api/test/integration/collections_api_test.rb +++ b/services/api/test/integration/collections_api_test.rb @@ -1,3 +1,7 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 + require 'test_helper' class CollectionsApiTest < ActionDispatch::IntegrationTest @@ -21,7 +25,7 @@ class CollectionsApiTest < ActionDispatch::IntegrationTest :filters => ['uuid', '=', 'ad02e37b6a7f45bbe2ead3c29a109b8a+54'].to_json }, auth(:active) assert_response 422 - assert_match /nvalid element.*not an array/, json_response['errors'].join(' ') + assert_match(/nvalid element.*not an array/, json_response['errors'].join(' ')) end test "get index with invalid filters (unsearchable column) responds 422" do @@ -30,7 +34,7 @@ class CollectionsApiTest < ActionDispatch::IntegrationTest :filters => [['this_column_does_not_exist', '=', 'bogus']].to_json }, auth(:active) assert_response 422 - assert_match /nvalid attribute/, json_response['errors'].join(' ') + assert_match(/nvalid attribute/, json_response['errors'].join(' ')) end test "get index with invalid filters (invalid operator) responds 422" do @@ -39,7 +43,7 @@ class CollectionsApiTest < ActionDispatch::IntegrationTest :filters => [['uuid', ':-(', 'displeased']].to_json }, auth(:active) assert_response 422 - assert_match /nvalid operator/, json_response['errors'].join(' ') + assert_match(/nvalid operator/, json_response['errors'].join(' ')) end test "get index with invalid filters (invalid operand type) responds 422" do @@ -48,7 +52,7 @@ class CollectionsApiTest < ActionDispatch::IntegrationTest :filters => [['uuid', '=', {foo: 'bar'}]].to_json }, auth(:active) assert_response 422 - assert_match /nvalid operand type/, json_response['errors'].join(' ') + assert_match(/nvalid operand type/, json_response['errors'].join(' ')) end test "get index with where= (empty string)" do @@ -57,6 +61,34 @@ class CollectionsApiTest < ActionDispatch::IntegrationTest assert_equal "arvados#collectionList", json_response['kind'] end + test "get index with select= (valid attribute)" do + get "/arvados/v1/collections", { + :format => :json, + :select => ['portable_data_hash'].to_json + }, auth(:active) + assert_response :success + assert json_response['items'][0].keys.include?('portable_data_hash') + assert not(json_response['items'][0].keys.include?('uuid')) + end + + test "get index with select= (invalid attribute) responds 422" do + get "/arvados/v1/collections", { + :format => :json, + :select => ['bogus'].to_json + }, auth(:active) + assert_response 422 + assert_match(/Invalid attribute.*bogus/, json_response['errors'].join(' ')) + end + + test "get index with select= (invalid attribute type) responds 422" do + get "/arvados/v1/collections", { + :format => :json, + :select => [['bogus']].to_json + }, auth(:active) + assert_response 422 + assert_match(/Invalid attribute.*bogus/, json_response['errors'].join(' ')) + end + test "controller 404 response is json" do get "/arvados/v1/thingsthatdonotexist", {:format => :xml}, auth(:active) assert_response 404 @@ -215,8 +247,6 @@ class CollectionsApiTest < ActionDispatch::IntegrationTest assert_response :success assert_equal true, json_response['manifest_text'].include?('file4_in_subdir4.txt') - created = json_response - # search using the filename search_using_full_text_search 'subdir2', 0 search_using_full_text_search 'subdir2:*', 1