X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/fbd54468b13466839c24d880a3d041d0a49371af..e97a5d828bdf7cb9626d72efd94d3bcf718a18c9:/services/api/test/functional/arvados/v1/query_test.rb diff --git a/services/api/test/functional/arvados/v1/query_test.rb b/services/api/test/functional/arvados/v1/query_test.rb index 91fe077503..dfa3b7fe77 100644 --- a/services/api/test/functional/arvados/v1/query_test.rb +++ b/services/api/test/functional/arvados/v1/query_test.rb @@ -1,10 +1,14 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 + require 'test_helper' class Arvados::V1::QueryTest < ActionController::TestCase test 'no fallback orders when order is unambiguous' do @controller = Arvados::V1::LogsController.new authorize_with :active - get :index, { + get :index, params: { order: ['id asc'], controller: 'logs', } @@ -15,7 +19,7 @@ class Arvados::V1::QueryTest < ActionController::TestCase test 'fallback orders when order is ambiguous' do @controller = Arvados::V1::LogsController.new authorize_with :active - get :index, { + get :index, params: { order: ['event_type asc'], controller: 'logs', } @@ -27,7 +31,7 @@ class Arvados::V1::QueryTest < ActionController::TestCase test 'skip fallback orders already given by client' do @controller = Arvados::V1::LogsController.new authorize_with :active - get :index, { + get :index, params: { order: ['modified_at asc'], controller: 'logs', } @@ -39,7 +43,7 @@ class Arvados::V1::QueryTest < ActionController::TestCase test 'eliminate superfluous orders' do @controller = Arvados::V1::LogsController.new authorize_with :active - get :index, { + get :index, params: { order: ['logs.modified_at asc', 'modified_at desc', 'event_type desc', @@ -54,7 +58,7 @@ class Arvados::V1::QueryTest < ActionController::TestCase test 'eliminate orders after the first unique column' do @controller = Arvados::V1::LogsController.new authorize_with :active - get :index, { + get :index, params: { order: ['event_type asc', 'id asc', 'uuid asc', @@ -65,4 +69,33 @@ class Arvados::V1::QueryTest < ActionController::TestCase assert_equal('logs.event_type asc, logs.id asc', assigns(:objects).order_values.join(', ')) end + + test 'do not count items_available if count=none' do + @controller = Arvados::V1::LinksController.new + authorize_with :active + get :index, params: { + count: 'none', + } + assert_response(:success) + refute(json_response.has_key?('items_available')) + end + + [{}, {count: nil}, {count: ''}, {count: 'exact'}].each do |params| + test "count items_available if params=#{params.inspect}" do + @controller = Arvados::V1::LinksController.new + authorize_with :active + get :index, params: params + assert_response(:success) + assert_operator(json_response['items_available'], :>, 0) + end + end + + test 'error if count=bogus' do + @controller = Arvados::V1::LinksController.new + authorize_with :active + get :index, params: { + count: 'bogus', + } + assert_response(422) + end end