X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/425f97db9a84540d608b7717b8df3befce687c8f..fc16c2ebbb92d9b0e52b6435b717f26b9680c7e6:/apps/workbench/test/controllers/collections_controller_test.rb diff --git a/apps/workbench/test/controllers/collections_controller_test.rb b/apps/workbench/test/controllers/collections_controller_test.rb index 14db674292..65349c6fbd 100644 --- a/apps/workbench/test/controllers/collections_controller_test.rb +++ b/apps/workbench/test/controllers/collections_controller_test.rb @@ -56,6 +56,25 @@ class CollectionsControllerTest < ActionController::TestCase assert_equal([['.', 'foo', 3]], assigns(:object).files) end + test "viewing a collection with spaces in filename" do + show_collection(:w_a_z_file, :active) + assert_equal([['.', 'w a z', 5]], assigns(:object).files) + end + + test "download a file with spaces in filename" do + collection = api_fixture('collections')['w_a_z_file'] + fakepipe = IO.popen(['echo', '-n', 'w a z'], 'rb') + IO.expects(:popen).with { |cmd, mode| + cmd.include? "#{collection['uuid']}/w a z" + }.returns(fakepipe) + get :show_file, { + uuid: collection['uuid'], + file: 'w a z' + }, session_for(:active) + assert_response :success + assert_equal 'w a z', response.body + end + test "viewing a collection fetches related projects" do show_collection({id: api_fixture('collections')["foo_file"]['portable_data_hash']}, :active) assert_includes(assigns(:same_pdh).map(&:owner_uuid), @@ -87,7 +106,7 @@ class CollectionsControllerTest < ActionController::TestCase test "viewing a collection fetches logs about it" do show_collection(:foo_file, :active) assert_includes(assigns(:logs).map(&:uuid), - api_fixture('logs')['log4']['uuid'], + api_fixture('logs')['system_adds_foo_file']['uuid'], "controller did not find related log") end @@ -147,6 +166,18 @@ class CollectionsControllerTest < ActionController::TestCase "failed to get a correct file from Keep") end + test 'anonymous download' do + Rails.configuration.anonymous_user_token = + api_fixture('api_client_authorizations')['anonymous']['api_token'] + expect_content = stub_file_content + get :show_file, { + uuid: api_fixture('collections')['user_agreement_in_anonymously_accessible_project']['uuid'], + file: 'GNU_General_Public_License,_version_3.pdf', + } + assert_response :success + assert_equal expect_content, response.body + end + test "can't get a file from Keep without permission" do params = collection_params(:foo_file, 'foo') sess = session_for(:spectator) @@ -174,12 +205,23 @@ class CollectionsControllerTest < ActionController::TestCase "using a reader token set the session's API token") end - test "trying to get from Keep with an unscoped reader token prompts login" do - params = collection_params(:foo_file, 'foo') - params[:reader_token] = - api_fixture('api_client_authorizations')['active_noscope']['api_token'] - get(:show_file, params) - assert_response :redirect + [false, api_fixture('api_client_authorizations')['anonymous']['api_token']]. + each do |anon_conf| + test "download a file using a reader token with insufficient scope (anon_conf=#{!!anon_conf})" do + Rails.configuration.anonymous_user_token = anon_conf + params = collection_params(:foo_file, 'foo') + params[:reader_token] = + api_fixture('api_client_authorizations')['active_noscope']['api_token'] + get(:show_file, params) + if anon_conf + # Some files can be shown without a valid token, but not this one. + assert_response 404 + else + # No files will ever be shown without a valid token. You + # should log in and try again. + assert_response :redirect + end + end end test "can get a file with an unpermissioned auth but in-scope reader token" do @@ -313,4 +355,79 @@ class CollectionsControllerTest < ActionController::TestCase assert /#{stage3_id}->#{stage3_out}/.match(used_by_svg) end + + test "view collection with empty properties" do + fixture_name = :collection_with_empty_properties + show_collection(fixture_name, :active) + assert_equal(api_fixture('collections')[fixture_name.to_s]['name'], assigns(:object).name) + assert_not_nil(assigns(:object).properties) + assert_empty(assigns(:object).properties) + end + + test "view collection with one property" do + fixture_name = :collection_with_one_property + show_collection(fixture_name, :active) + fixture = api_fixture('collections')[fixture_name.to_s] + assert_equal(fixture['name'], assigns(:object).name) + assert_equal(fixture['properties'][0], assigns(:object).properties[0]) + end + + test "create collection with properties" do + post :create, { + collection: { + name: 'collection created with properties', + manifest_text: '', + properties: { + property_1: 'value_1' + }, + }, + format: :json + }, session_for(:active) + assert_response :success + assert_not_nil assigns(:object).uuid + assert_equal 'collection created with properties', assigns(:object).name + assert_equal 'value_1', assigns(:object).properties[:property_1] + end + + test "update description and check manifest_text is not lost" do + collection = api_fixture("collections")["multilevel_collection_1"] + post :update, { + id: collection["uuid"], + collection: { + description: 'test description update' + }, + format: :json + }, session_for(:active) + assert_response :success + assert_not_nil assigns(:object) + assert_equal 'test description update', assigns(:object).description + assert_equal collection['manifest_text'], assigns(:object).manifest_text + end + + test "view collection and verify none of the file types listed are disabled" do + show_collection(:collection_with_several_supported_file_types, :active) + + files = assigns(:object).files + assert_equal true, files.length>0, "Expected one or more files in collection" + + disabled = css_select('[disabled="disabled"]').collect do |el| + el + end + assert_equal 0, disabled.length, "Expected no disabled files in collection viewables list" + end + + test "view collection and verify file types listed are all disabled" do + show_collection(:collection_with_several_unsupported_file_types, :active) + + files = assigns(:object).files.collect do |_, file, _| + file + end + assert_equal true, files.length>0, "Expected one or more files in collection" + + disabled = css_select('[disabled="disabled"]').collect do |el| + el.attributes['title'].split[-1] + end + + assert_equal files.sort, disabled.sort, "Expected to see all collection files in disabled list of files" + end end