X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/e3c48fef662408636cb49fe1bb0a3c1040269e7c..1c5176d87df0dbd25db6ff1fb2ab82ae17472145:/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 5fa77c3db9..b0fddb8f29 100644 --- a/services/api/test/integration/collections_api_test.rb +++ b/services/api/test/integration/collections_api_test.rb @@ -6,33 +6,69 @@ class CollectionsApiTest < ActionDispatch::IntegrationTest test "should get index" do get "/arvados/v1/collections", {:format => :json}, auth(:active) assert_response :success - assert_equal "arvados#collectionList", jresponse['kind'] + assert_equal "arvados#collectionList", json_response['kind'] end test "get index with filters= (empty string)" do get "/arvados/v1/collections", {:format => :json, :filters => ''}, auth(:active) assert_response :success - assert_equal "arvados#collectionList", jresponse['kind'] + assert_equal "arvados#collectionList", json_response['kind'] + end + + test "get index with invalid filters (array of strings) responds 422" do + get "/arvados/v1/collections", { + :format => :json, + :filters => ['uuid', '=', 'ad02e37b6a7f45bbe2ead3c29a109b8a+54'].to_json + }, auth(:active) + assert_response 422 + assert_match /nvalid element.*not an array/, json_response['errors'].join(' ') + end + + test "get index with invalid filters (unsearchable column) responds 422" do + get "/arvados/v1/collections", { + :format => :json, + :filters => [['this_column_does_not_exist', '=', 'bogus']].to_json + }, auth(:active) + assert_response 422 + assert_match /nvalid attribute/, json_response['errors'].join(' ') + end + + test "get index with invalid filters (invalid operator) responds 422" do + get "/arvados/v1/collections", { + :format => :json, + :filters => [['uuid', ':-(', 'displeased']].to_json + }, auth(:active) + assert_response 422 + assert_match /nvalid operator/, json_response['errors'].join(' ') + end + + test "get index with invalid filters (invalid operand type) responds 422" do + get "/arvados/v1/collections", { + :format => :json, + :filters => [['uuid', '=', {foo: 'bar'}]].to_json + }, auth(:active) + assert_response 422 + assert_match /nvalid operand type/, json_response['errors'].join(' ') end test "get index with where= (empty string)" do get "/arvados/v1/collections", {:format => :json, :where => ''}, auth(:active) assert_response :success - assert_equal "arvados#collectionList", jresponse['kind'] + assert_equal "arvados#collectionList", json_response['kind'] end test "controller 404 response is json" do get "/arvados/v1/thingsthatdonotexist", {:format => :xml}, auth(:active) assert_response 404 - assert_equal 1, jresponse['errors'].length - assert_equal true, jresponse['errors'][0].is_a?(String) + assert_equal 1, json_response['errors'].length + assert_equal true, json_response['errors'][0].is_a?(String) end test "object 404 response is json" do get "/arvados/v1/groups/zzzzz-j7d0g-o5ba971173cup4f", {}, auth(:active) assert_response 404 - assert_equal 1, jresponse['errors'].length - assert_equal true, jresponse['errors'][0].is_a?(String) + assert_equal 1, json_response['errors'].length + assert_equal true, json_response['errors'][0].is_a?(String) end test "store collection as json" do @@ -41,6 +77,6 @@ class CollectionsApiTest < ActionDispatch::IntegrationTest collection: "{\"manifest_text\":\". bad42fa702ae3ea7d888fef11b46f450+44 0:44:md5sum.txt\\n\",\"uuid\":\"ad02e37b6a7f45bbe2ead3c29a109b8a+54\"}" }, auth(:active) assert_response 200 - assert_equal 'ad02e37b6a7f45bbe2ead3c29a109b8a+54', jresponse['uuid'] + assert_equal 'ad02e37b6a7f45bbe2ead3c29a109b8a+54', json_response['uuid'] end end