2659: (1) Update link_to_if_arvados_object method to display an object name as link...
[arvados.git] / apps / workbench / test / integration / anonymous_access_test.rb
index 87bbe84d49933c6b828a27d7e883b75fb618c44f..43783bd0cac2fbb470b828dcdcc782ef322500d2 100644 (file)
@@ -38,59 +38,227 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest
         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'
+          assert_selector 'a', text: 'Log in'
+          assert_no_selector 'a', text: 'Log out'
         end
       end
     end
   end
 
+  def visit_publicly_accessible_project token=nil, use_config=true, path=nil
+    if use_config
+      Rails.configuration.anonymous_user_token = api_fixture('api_client_authorizations')['anonymous']['api_token']
+    else
+      Rails.configuration.anonymous_user_token = false
+    end
+
+    path = "/projects/#{api_fixture('groups')['anonymously_accessible_project']['uuid']}/?public_data=true" if !path
+
+    if token
+        visit page_with_token(token, path)
+    else
+      visit path
+    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']
+    test "visit public project as user #{token.inspect} when anonymous browsing is enabled" do
+      visit_publicly_accessible_project token
+      verify_homepage_anonymous_enabled user, is_active, has_profile
+    end
+  end
 
-      path = "/projects/#{api_fixture('groups')['anonymously_accessible_project']['uuid']}/?public_data=true"
+  test "anonymous user visit public project when anonymous browsing not enabled and expect to see login page" do
+    visit_publicly_accessible_project nil, false
+    assert_text 'Please log in'
+  end
 
-      if !token
-        visit path
-      else
-        visit page_with_token(token, path)
-      end
-      verify_homepage_anonymous_enabled user, is_active, has_profile
+  test "visit non-public project as anonymous when anonymous browsing is enabled and expect page not found" do
+    visit_publicly_accessible_project nil, true,
+        "/projects/#{api_fixture('groups')['aproject']['uuid']}/?public_data=true"
+    assert_text 'Not Found'
+  end
+
+  test "selection actions when anonymous user accesses shared project" do
+    visit_publicly_accessible_project
+
+    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_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
 
   [
-    [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
+    ['All pipelines', 'Pipeline in publicly accessible project'],
+    ['All jobs', 'job submitted'],
+    ['All collections', 'GNU_General_Public_License,_version_3.pdf'],
+  ].each do |selector, expectation|
+    test "verify dashboard when anonymous user accesses shared project and click #{selector}" do
+      visit_publicly_accessible_project
+
+      # go to dashboard
+      click_link 'You are viewing public data'
+
+      assert_no_selector 'a', text: 'Run a pipeline'
+      assert_selector 'a', text: selector
+      click_link selector
+      assert_text expectation
+    end
+  end
+
+  test "anonymous user accesses data collections tab in shared project" do
+    visit_publicly_accessible_project
+
+    assert_selector 'a', text: 'Data collections (1)'
+
+    # click on show collection
+    within first('tr[data-kind="arvados#collection"]') do
+      click_link 'Show'
+    end
+
+    # in collection page
+    assert_no_selector 'input', text: 'Create sharing link'
+    assert_no_selector 'a', text: 'Upload'
+    assert_no_selector 'button', 'Selection'
+
+    within ('#collection_files') do
+      assert_text 'GNU_General_Public_License,_version_3.pdf'
+      # how do i assert the view and download link existence?
+    end
+  end
 
-      path = "/projects/#{api_fixture('groups')['anonymously_accessible_project']['uuid']}/?public_data=true"
-      if !token
-        visit path
+  [
+    [nil, 'job'],
+    [nil, 'pipelineInstance'],
+    ['admin', 'job'],
+    ['admin', 'pipelineInstance'],
+  ].each do |token, type|
+    test "user #{token.inspect} accesses jobs and pipelines tab in shared project and clicks on #{type}" do
+      visit_publicly_accessible_project token
+
+      assert_selector 'a', 'Jobs and pipelines (2)'
+
+      click_link 'Jobs and pipelines'
+      assert_text 'Pipeline in publicly accessible project'
+
+      # click on type specified collection
+      if type == 'job'
+        verify_job_row token
       else
-        visit page_with_token(token, path)
+        verify_pipeline_instance_row token
       end
+    end
+  end
+
+  def verify_job_row user
+    within first('tr[data-kind="arvados#job"]') do
+      click_link 'Show'
+    end
+    assert_text 'script_version'
+    if user
+      assert_selector 'a', text: 'Active User'  # modified by user
+      assert_selector 'a', text: 'Log'
+      assert_selector 'a', text: 'Move job'
+      assert_selector 'button', text: 'Cancel'
+    else
+      assert_text 'zzzzz-tpzed-xurymjxw79nv3jz' # modified by user
+      assert_no_selector 'a', text: 'zzzzz-tpzed-xurymjxw79nv3jz'
+      assert_no_selector 'a', text: 'Log'
+      assert_no_selector 'a', text: 'Move job'
+      assert_no_selector 'a', text: 'Re-run job'
+    end
+  end
+
+  def verify_pipeline_instance_row user
+    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'
+    if user
+      assert_selector 'a', text: 'Re-run with latest'
+      assert_selector 'a', text: 'Re-run options'
+    else
+      assert_no_selector 'a', text: 'Re-run with latest'
+      assert_no_selector 'a', text: 'Re-run options'
+    end
+  end
 
-      if user
-        assert_text 'Unrestricted public data'
+  test "anonymous user accesses pipeline templates tab in shared project" do
+    visit_publicly_accessible_project
+
+    assert_selector 'a', 'Pipeline templates (1)'
+
+    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
+
+  [
+    [nil, '/users'],
+    [nil, '/groups'],
+    ['admin', '/users'],
+    ['admin', '/groups'],
+  ].each do |token, page|
+    test "user #{token.inspect} accesses publicly accessible project and then traverses to #{page}" do
+      # go to the page
+      if token
+        visit page_with_token(token, page)
       else
-        assert_text 'Please log in'
+        # when anonymous, first visit publicly accessible project
+        visit_publicly_accessible_project token if !token
+        visit page
+      end
+
+      if page == '/users'
+        verify_users_page token
+      elsif page == '/groups'
+        verify_groups_page token
       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_users_page user
+    assert_text 'user'
+    if user
+      assert_selector 'a', text: 'Add a new user'
+    else
+      assert_no_selector 'a', text: 'Add a new user'
+    end
+  end
+
+  def verify_groups_page user
+    assert_text 'Group'
+    if user
+      assert_selector 'button', text: 'Add a new group'
+    else
+      assert_no_selector 'button', text: 'Add a new group'
+    end
   end
 end