X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/2115f4609adcc86156e8e0aa59ea38ba5808378e..5cc1710b57f98905469225c68d975ad2e3e7e56d:/services/api/test/functional/arvados/v1/filters_test.rb diff --git a/services/api/test/functional/arvados/v1/filters_test.rb b/services/api/test/functional/arvados/v1/filters_test.rb index dd8eeaa7be..5d343314ce 100644 --- a/services/api/test/functional/arvados/v1/filters_test.rb +++ b/services/api/test/functional/arvados/v1/filters_test.rb @@ -39,6 +39,41 @@ class Arvados::V1::FiltersTest < ActionController::TestCase assert_match(/no longer supported/, json_response['errors'].join(' ')) end + test 'error message for int64 overflow' do + # some versions of ActiveRecord cast >64-bit ints to postgres + # numeric type, but this is never useful because database content + # is 64 bit. + @controller = Arvados::V1::LogsController.new + authorize_with :active + get :index, params: { + filters: [['id', '=', 123412341234123412341234]], + } + assert_response 422 + assert_match(/Invalid operand .* integer attribute/, json_response['errors'].join(' ')) + end + + ['in', 'not in'].each do |operator| + test "error message for int64 overflow ('#{operator}' filter)" do + @controller = Arvados::V1::ContainerRequestsController.new + authorize_with :active + get :index, params: { + filters: [['priority', operator, [9, 123412341234123412341234]]], + } + assert_response 422 + assert_match(/Invalid element .* integer attribute/, json_response['errors'].join(' ')) + end + end + + test 'error message for invalid boolean operand' do + @controller = Arvados::V1::GroupsController.new + authorize_with :active + get :index, params: { + filters: [['is_trashed', '=', 'fourty']], + } + assert_response 422 + assert_match(/Invalid operand .* boolean attribute/, json_response['errors'].join(' ')) + end + test 'api responses provide timestamps with nanoseconds' do @controller = Arvados::V1::CollectionsController.new authorize_with :active @@ -236,6 +271,58 @@ class Arvados::V1::FiltersTest < ActionController::TestCase json_response['errors'].join(' ')) end + test "groups contents with properties filter succeeds on objects with properties field" do + @controller = Arvados::V1::GroupsController.new + authorize_with :admin + get :contents, params: { + filters: [ + ['properties', 'exists', 'foo'], + ['uuid', 'is_a', ["arvados#group","arvados#collection","arvados#containerRequest"]], + ] + } + assert_response 200 + assert json_response['items'].length == 0 + end + + # Tests bug #19297 + test "groups contents with properties filter succeeds on some objects with properties field" do + @controller = Arvados::V1::GroupsController.new + authorize_with :admin + get :contents, params: { + filters: [ + ['properties', 'exists', 'foo'], + ['uuid', 'is_a', ["arvados#group","arvados#workflow"]], + ] + } + assert_response 200 + assert json_response['items'].length == 0 + end + + # Tests bug #19297 + test "groups contents with properties filter fails on objects without properties field" do + @controller = Arvados::V1::GroupsController.new + authorize_with :admin + get :contents, params: { + filters: [ + ['properties', 'exists', 'foo'], + ['uuid', 'is_a', ["arvados#workflow"]], + ] + } + assert_response 422 + assert_match(/Invalid attribute 'properties' for operator 'exists'.*on object type Workflow/, json_response['errors'].join(' ')) + end + + test "groups contents without filters and limit=0, count=none" do + @controller = Arvados::V1::GroupsController.new + authorize_with :admin + get :contents, params: { + limit: 0, + count: 'none', + } + assert_response 200 + assert json_response['items'].length == 0 + end + test "replication_desired = 2" do @controller = Arvados::V1::CollectionsController.new authorize_with :admin