X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/7d9cfb6e0716239f996bae054bc9345a663e0b7e..b3f3c28f67519f23a4b734b2a75eaf4f32c0049f:/apps/workbench/test/functional/collections_controller_test.rb diff --git a/apps/workbench/test/functional/collections_controller_test.rb b/apps/workbench/test/functional/collections_controller_test.rb index b334f9ff27..50577ede85 100644 --- a/apps/workbench/test/functional/collections_controller_test.rb +++ b/apps/workbench/test/functional/collections_controller_test.rb @@ -181,4 +181,20 @@ class CollectionsControllerTest < ActionController::TestCase show_collection({uuid: NONEXISTENT_COLLECTION, id: NONEXISTENT_COLLECTION}, :active, 404) end + + test "use a reasonable read buffer even if client requests a huge range" do + fakefiledata = mock + IO.expects(:popen).returns(fakefiledata) + fakefiledata.expects(:read).twice.with() do |length| + # Fail the test if read() is called with length>1MiB: + length < 2**20 + end.returns("foo\n", nil) + fakefiledata.expects(:close) + foo_file = api_fixture('collections')['foo_file'] + @request.headers['Range'] = 'bytes=0-4294967296/*' + get :show_file, { + uuid: foo_file['uuid'], + file: foo_file['manifest_text'].match(/ \d+:\d+:(\S+)/)[1] + }, session_for(:active) + end end