X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/94a3addbee3e4a293ba23483dc34ae316d93fbdd..8c19d0da4331ba9c2605543f70c0f55875f41497:/apps/workbench/test/integration/anonymous_access_test.rb diff --git a/apps/workbench/test/integration/anonymous_access_test.rb b/apps/workbench/test/integration/anonymous_access_test.rb index 87bbe84d49..09e3330063 100644 --- a/apps/workbench/test/integration/anonymous_access_test.rb +++ b/apps/workbench/test/integration/anonymous_access_test.rb @@ -8,39 +8,30 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest setup do need_javascript + Rails.configuration.anonymous_user_token = api_fixture('api_client_authorizations')['anonymous']['api_token'] end - def verify_homepage_anonymous_enabled user, is_active, has_profile + PUBLIC_PROJECT = "/projects/#{api_fixture('groups')['anonymously_accessible_project']['uuid']}" + + def verify_site_navigation_anonymous_enabled user, is_active if user if user['is_active'] - if has_profile - assert_text 'Unrestricted public data' - assert_selector 'a', text: 'Projects' - else - assert_text 'All required fields must be completed before you can proceed' - end + assert_text 'Unrestricted public data' + assert_selector 'a', text: 'Projects' else assert_text 'indicate that you have read and accepted the user agreement' end within('.navbar-fixed-top') do - assert_no_text 'You are viewing public data' assert_selector 'a', text: "#{user['email']}" find('a', text: "#{user['email']}").click within('.dropdown-menu') do assert_selector 'a', text: 'Log out' end end - else + else # anonymous assert_text 'Unrestricted public data' within('.navbar-fixed-top') do - assert_text 'You are viewing public data' - anonymous_user = api_fixture('users')['anonymous'] - assert_selector 'a', "#{anonymous_user['email']}" - find('a', text: "#{anonymous_user['email']}").click - within('.dropdown-menu') do - assert_selector 'a', text: 'Log out' - #assert_selector 'a', 'Log in' - end + assert_selector 'a', text: 'Log in' end end end @@ -49,48 +40,139 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest [nil, nil, false, false], ['inactive', api_fixture('users')['inactive'], false, false], ['active', api_fixture('users')['active'], true, true], - ['active_no_prefs_profile', api_fixture('users')['active_no_prefs_profile'], true, false], - ['admin', api_fixture('users')['admin'], true, true], - ].each do |token, user, is_active, has_profile| - test "visit public project as user #{token} when anonymous browsing is enabled" do - Rails.configuration.anonymous_user_token = api_fixture('api_client_authorizations')['anonymous']['api_token'] - - path = "/projects/#{api_fixture('groups')['anonymously_accessible_project']['uuid']}/?public_data=true" - + ].each do |token, user, is_active| + test "visit public project as user #{token.inspect} when anonymous browsing is enabled" do if !token - visit path + visit PUBLIC_PROJECT else - visit page_with_token(token, path) + visit page_with_token(token, PUBLIC_PROJECT) end - verify_homepage_anonymous_enabled user, is_active, has_profile + + verify_site_navigation_anonymous_enabled user, is_active end end + test "selection actions when anonymous user accesses shared project" do + visit PUBLIC_PROJECT + + assert_selector 'a', text: 'Description' + assert_selector 'a', text: 'Data collections' + assert_selector 'a', text: 'Jobs and pipelines' + assert_selector 'a', text: 'Pipeline templates' + assert_selector 'a', text: 'Advanced' + assert_no_selector 'a', text: 'Subprojects' + assert_no_selector 'a', text: 'Other objects' + assert_no_selector 'button', text: 'Add data' + + click_link 'Data collections' + click_button 'Selection' + within('.selection-action-container') do + assert_selector 'li', text: 'Compare selected' + assert_no_selector 'li', text: 'Create new collection with selected collections' + assert_no_selector 'li', text: 'Copy selected' + assert_no_selector 'li', text: 'Move selected' + assert_no_selector 'li', text: 'Remove selected' + end + end + + test "anonymous user accesses data collections tab in shared project" do + visit PUBLIC_PROJECT + click_link 'Data collections' + collection = api_fixture('collections')['user_agreement_in_anonymously_accessible_project'] + assert_text 'GNU General Public License' + + assert_selector 'a', text: 'Data collections' + + # click on show collection + within "tr[data-object-uuid=\"#{collection['uuid']}\"]" do + click_link 'Show' + end + + # in collection page + assert_no_selector 'input', text: 'Create sharing link' + assert_no_text 'Sharing and permissions' + assert_no_selector 'a', text: 'Upload' + assert_no_selector 'button', 'Selection' + + within '#collection_files tr,li', text: 'GNU_General_Public_License,_version_3.pdf' do + find 'a[title~=View]' + find 'a[title~=Download]' + end + end + + test 'view file' do + magic = rand(2**512).to_s 36 + CollectionsController.any_instance.stubs(:file_enumerator).returns([magic]) + collection = api_fixture('collections')['public_text_file'] + visit '/collections/' + collection['uuid'] + find('tr,li', text: 'Hello world.txt'). + find('a[title~=View]').click + assert_text magic + end + [ - [nil, nil], - ['active', api_fixture('users')['active']], - ].each do |token, user, is_active| - test "visit public project as user #{token} when anonymous browsing is not enabled" do - Rails.configuration.anonymous_user_token = false + 'running_job', + 'completed_job', + 'pipelineInstance' + ].each do |type| + test "anonymous user accesses jobs and pipelines tab in shared project and clicks on #{type}" do + visit PUBLIC_PROJECT + click_link 'Data collections' + assert_text 'GNU General Public License' - path = "/projects/#{api_fixture('groups')['anonymously_accessible_project']['uuid']}/?public_data=true" - if !token - visit path - else - visit page_with_token(token, path) - end + click_link 'Jobs and pipelines' + assert_text 'Pipeline in publicly accessible project' - if user - assert_text 'Unrestricted public data' + # click on the specified job + if type.include? 'job' + verify_job_row type else - assert_text 'Please log in' + verify_pipeline_instance_row end end end - test "visit non-public project as anonymous when anonymous browsing is enabled and expect page not found" do - Rails.configuration.anonymous_user_token = api_fixture('api_client_authorizations')['anonymous']['api_token'] - visit "/projects/#{api_fixture('groups')['aproject']['uuid']}/?public_data=true" - assert_text 'Not Found' + def verify_job_row look_for + within first('tr', text: look_for) do + click_link 'Show' + end + assert_text 'script_version' + + assert_text 'zzzzz-tpzed-xurymjxw79nv3jz' # modified by user + assert_no_selector 'a', text: 'zzzzz-tpzed-xurymjxw79nv3jz' + assert_no_selector 'a', text: 'Move job' + assert_no_selector 'button', text: 'Cancel' + assert_no_selector 'button', text: 'Re-run job' + end + + def verify_pipeline_instance_row + within first('tr[data-kind="arvados#pipelineInstance"]') do + assert_text 'Pipeline in publicly accessible project' + click_link 'Show' + end + + # in pipeline instance page + assert_text 'This pipeline is complete' + assert_no_selector 'a', text: 'Re-run with latest' + assert_no_selector 'a', text: 'Re-run options' + end + + test "anonymous user accesses pipeline templates tab in shared project" do + visit PUBLIC_PROJECT + click_link 'Data collections' + assert_text 'GNU General Public License' + + assert_selector 'a', text: 'Pipeline templates' + + click_link 'Pipeline templates' + assert_text 'Pipeline template in publicly accessible project' + + within first('tr[data-kind="arvados#pipelineTemplate"]') do + click_link 'Show' + end + + # in template page + assert_text 'script version' + assert_no_selector 'a', text: 'Run this pipeline' end end