X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/66da04e142bb80ff25d65900292bf99c7e4252f2..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 56db54c3a4..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', } @@ -23,4 +27,75 @@ class Arvados::V1::QueryTest < ActionController::TestCase assert_equal('logs.event_type asc, logs.modified_at desc, logs.uuid', assigns(:objects).order_values.join(', ')) end + + test 'skip fallback orders already given by client' do + @controller = Arvados::V1::LogsController.new + authorize_with :active + get :index, params: { + order: ['modified_at asc'], + controller: 'logs', + } + assert_response :success + assert_equal('logs.modified_at asc, logs.uuid', + assigns(:objects).order_values.join(', ')) + end + + test 'eliminate superfluous orders' do + @controller = Arvados::V1::LogsController.new + authorize_with :active + get :index, params: { + order: ['logs.modified_at asc', + 'modified_at desc', + 'event_type desc', + 'logs.event_type asc'], + controller: 'logs', + } + assert_response :success + assert_equal('logs.modified_at asc, logs.event_type desc, logs.uuid', + assigns(:objects).order_values.join(', ')) + end + + test 'eliminate orders after the first unique column' do + @controller = Arvados::V1::LogsController.new + authorize_with :active + get :index, params: { + order: ['event_type asc', + 'id asc', + 'uuid asc', + 'modified_at desc'], + controller: 'logs', + } + assert_response :success + 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