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: Rails.configuration.site_name.downcase
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_text Rails.configuration.site_name.downcase
+ assert_no_selector 'a', text: Rails.configuration.site_name.downcase
+ assert_selector 'a', text: 'Log in'
end
end
end
[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
+ assert page.has_no_selector?('[value*="GNU_General_Public_License"]')
+ 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