X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/7afe2c73ccdaad21b2d36b345a1627c1ad3f51a1..7d5d40c55d2a38b12e810f3b9d3e168ee434cbd2:/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 9f31ef9486..7d3dfabd64 100644 --- a/apps/workbench/test/integration/anonymous_access_test.rb +++ b/apps/workbench/test/integration/anonymous_access_test.rb @@ -18,13 +18,17 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest if user['is_active'] assert_text 'Unrestricted public data' assert_selector 'a', text: 'Projects' + page.find("#projects-menu").click + assert_selector 'a', text: 'Add a new project' + assert_selector 'a', text: 'Browse public projects' + assert page.has_text?('Projects shared with me'), 'Not found text - Project shared with me' else assert_text 'indicate that you have read and accepted the user agreement' end within('.navbar-fixed-top') do assert_selector 'a', text: Rails.configuration.site_name.downcase - assert_selector 'a', text: "#{user['email']}" - find('a', text: "#{user['email']}").click + assert(page.has_link?("notifications-menu"), 'no user menu') + page.find("#notifications-menu").click within('.dropdown-menu') do assert_selector 'a', text: 'Log out' end @@ -35,6 +39,7 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest assert_text Rails.configuration.site_name.downcase assert_no_selector 'a', text: Rails.configuration.site_name.downcase assert_selector 'a', text: 'Log in' + assert_selector 'a', text: 'Browse public projects' end end end @@ -62,8 +67,8 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest assert_selector 'a', text: 'Data collections' assert_selector 'a', text: 'Jobs and pipelines' assert_selector 'a', text: 'Pipeline templates' + assert_selector 'a', text: 'Subprojects' 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' @@ -183,6 +188,19 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest assert_no_selector 'a', text: 'Run this pipeline' end + test "anonymous user accesses subprojects tab in shared project" do + visit PUBLIC_PROJECT + '#Subprojects' + + assert_text 'Subproject in anonymous accessible project' + + within first('tr[data-kind="arvados#group"]') do + click_link 'Show' + end + + # in subproject + assert_text 'Description for subproject in anonymous accessible project' + end + [ ['pipeline_in_publicly_accessible_project', true], ['pipeline_in_publicly_accessible_project_but_other_objects_elsewhere', false], @@ -198,9 +216,11 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest if pipeline_page object = api_fixture('pipeline_instances')[fixture] page = "/pipeline_instances/#{object['uuid']}" + expect_log_text = "Log for foo" else # job object = api_fixture('jobs')[fixture] page = "/jobs/#{object['uuid']}" + expect_log_text = "stderr crunchstat" end if user @@ -213,30 +233,29 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest click_link 'foo' if pipeline_page if objects_readable + assert_selector 'a[href="#Log"]', text: 'Log' + assert_no_selector 'a[data-toggle="disabled"]', text: 'Log' + assert_no_text 'Output data not available' if pipeline_page assert_text 'This pipeline was created from' assert_selector 'a', text: object['components']['foo']['job']['uuid'] + # We'd like to test the Log tab on job pages too, but we can't right + # now because Poltergeist 1.x doesn't support JavaScript's + # Function.prototype.bind, which is used by job_log_graph.js. + click_link "Log" + assert_text expect_log_text end - assert_no_text 'Output data not available' - assert_selector 'a[href="#Log"]', text: 'Log' - assert_no_selector 'a[data-toggle="disabled"]', text: 'Log' else + assert_selector 'a[data-toggle="disabled"]', text: 'Log' + assert_text 'Output data not available' + assert_text object['job'] if pipeline_page assert_no_text 'This pipeline was created from' # template is not readable assert_no_selector 'a', text: object['components']['foo']['job']['uuid'] end + click_link "Log" assert_text 'Output data not available' - assert_text object['job'] - assert_selector 'a[data-toggle="disabled"]', text: 'Log' - end - - click_link 'Log' - if objects_readable - assert_no_text 'foo' # should be in Log tab - assert_text 'stderr crunchstat' if pipeline_page - else - assert_text 'foo' # Log tab disabled and hence still in first tab - assert_no_text 'stderr crunchstat' # log line shouldn't be seen + assert_no_text expect_log_text end end end @@ -247,7 +266,9 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest ['new_pipeline_in_publicly_accessible_project_but_other_objects_elsewhere', false], ['new_pipeline_in_publicly_accessible_project_but_other_objects_elsewhere', false, 'spectator'], ['new_pipeline_in_publicly_accessible_project_but_other_objects_elsewhere', true, 'admin'], + ['new_pipeline_in_publicly_accessible_project_with_dataclass_file_and_other_objects_elsewhere', false], ['new_pipeline_in_publicly_accessible_project_with_dataclass_file_and_other_objects_elsewhere', false, 'spectator'], + ['new_pipeline_in_publicly_accessible_project_with_dataclass_file_and_other_objects_elsewhere', true, 'admin'], ].each do |fixture, objects_readable, user=nil| test "access #{fixture} in public project with objects readable=#{objects_readable} with user #{user}" do object = api_fixture('pipeline_instances')[fixture] @@ -274,27 +295,19 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest end else assert_no_text 'This pipeline was created from' # template is not readable - assert_no_selector 'a', text: object['components']['foo']['script_parameters']['input']['value'] + input = object['components']['foo']['script_parameters']['input']['value'] + assert_no_selector 'a', text: input if user + input = input.gsub('/', '\\/') assert_text "One or more inputs provided are not readable" - assert_selector "input[type=text][value=#{object['components']['foo']['script_parameters']['input']['value']}]" + assert_selector "input[type=text][value=#{input}]" assert_selector 'a.disabled', text: 'Run' else assert_no_text "One or more inputs provided are not readable" - assert_text object['components']['foo']['script_parameters']['input']['value'] + assert_text input assert_no_selector 'a', text: 'Run' end end end end - - test "anonymous user accesses collection in shared project" do - visit "/collections/#{api_fixture('collections')['public_text_file']['uuid']}" - - # in collection page - assert_text 'Public Projects Unrestricted public data' - assert_text 'Hello world' - assert_text 'Content address' - assert_selector 'a', text: 'Provenance graph' - end end