[ARVADOS] updated: 093cebc3a4baed645fd5d4a5331c2ff837de8c77
git at public.curoverse.com
git at public.curoverse.com
Wed Nov 12 13:13:03 EST 2014
Summary of changes:
.../test/unit/arvados_resource_list_test.rb | 30 +++++++++++++++++++---
services/api/lib/load_param.rb | 7 +++--
2 files changed, 32 insertions(+), 5 deletions(-)
via 093cebc3a4baed645fd5d4a5331c2ff837de8c77 (commit)
from 91f0b180a8474321738577a12250b5a1b8f5bcbc (commit)
Those revisions listed above that are new to this repository have
not appeared on any other notification email; so we list those
revisions in full, below.
commit 093cebc3a4baed645fd5d4a5331c2ff837de8c77
Author: Tom Clegg <tom at curoverse.com>
Date: Thu Nov 6 22:52:44 2014 -0500
3400: test limit between server maxpagesize and 2x server maxpagesize.
Conflicts:
apps/workbench/test/unit/arvados_resource_list_test.rb
diff --git a/apps/workbench/test/unit/arvados_resource_list_test.rb b/apps/workbench/test/unit/arvados_resource_list_test.rb
index 0955d52..6494bc5 100644
--- a/apps/workbench/test/unit/arvados_resource_list_test.rb
+++ b/apps/workbench/test/unit/arvados_resource_list_test.rb
@@ -35,13 +35,37 @@ class ResourceListTest < ActiveSupport::TestCase
assert_equal 51, a
end
- test 'get limited items more than default page size' do
+ test 'get limited items, limit % page_size != 0' do
+ skip "Requires server MAX_LIMIT < 200 which is not currently the default"
+
use_token :admin
+ max_page_size = Collection.
+ where(owner_uuid: 'zzzzz-j7d0g-0201collections').
+ limit(1000000000).
+ fetch_multiple_pages(false).
+ count
+ # Conditions necessary for this test to be valid:
+ assert_operator 200, :>, max_page_size
+ assert_operator 1, :<, max_page_size
+ # Verify that the server really sends max_page_size when asked for max_page_size+1
+ assert_equal max_page_size, Collection.
+ where(owner_uuid: 'zzzzz-j7d0g-0201collections').
+ limit(max_page_size+1).
+ fetch_multiple_pages(false).
+ results.
+ count
+ # Now that we know the max_page_size+1 is in the middle of page 2,
+ # make sure #each returns page 1 and only the requested part of
+ # page 2.
a = 0
- Collection.where(owner_uuid: 'zzzzz-j7d0g-0201collections').limit(110).each do
+ saw_uuid = {}
+ Collection.where(owner_uuid: 'zzzzz-j7d0g-0201collections').limit(max_page_size+1).each do |item|
a += 1
+ saw_uuid[item.uuid] = true
end
- assert_equal 110, a
+ assert_equal max_page_size+1, a
+ # Ensure no overlap between pages
+ assert_equal max_page_size+1, saw_uuid.size
end
test 'get single page of items' do
diff --git a/services/api/lib/load_param.rb b/services/api/lib/load_param.rb
index 8d5a9d2..3f1a3b2 100644
--- a/services/api/lib/load_param.rb
+++ b/services/api/lib/load_param.rb
@@ -6,9 +6,12 @@
# @where, @filters, @limit, @offset, @orders
module LoadParam
- # Default limit on number of rows to return in a single query.
+ # Default number of rows to return in a single query.
DEFAULT_LIMIT = 100
+ # Maximum number of rows to return in a single query, even if the client asks for more.
+ MAX_LIMIT = 1000
+
# Load params[:where] into @where
def load_where_param
if params[:where].nil? or params[:where] == ""
@@ -55,7 +58,7 @@ module LoadParam
unless params[:limit].to_s.match(/^\d+$/)
raise ArgumentError.new("Invalid value for limit parameter")
end
- @limit = params[:limit].to_i
+ @limit = [params[:limit].to_i, MAX_LIMIT].min
else
@limit = DEFAULT_LIMIT
end
-----------------------------------------------------------------------
hooks/post-receive
--
More information about the arvados-commits
mailing list