5365: additional test assertions for pipeline log tab display
[arvados.git] / apps / workbench / test / integration / anonymous_access_test.rb
index 6508879099d8252c5ca2d9561cb961661174acb4..62342ad099a027f37352dde0bf6ccd8e9e691b16 100644 (file)
@@ -22,6 +22,7 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest
         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
         within('.dropdown-menu') do
@@ -31,6 +32,8 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest
     else  # anonymous
       assert_text 'Unrestricted public data'
       within('.navbar-fixed-top') do
+        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
@@ -55,6 +58,7 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest
   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'
@@ -63,6 +67,7 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest
     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'
@@ -75,6 +80,7 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest
 
   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'
 
@@ -92,6 +98,7 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest
     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
@@ -114,6 +121,7 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest
   ].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'
 
       click_link 'Jobs and pipelines'
@@ -155,6 +163,7 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest
 
   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'
@@ -170,4 +179,46 @@ class AnonymousAccessTest < ActionDispatch::IntegrationTest
     assert_text 'script version'
     assert_no_selector 'a', text: 'Run this pipeline'
   end
+
+  [
+    ['pipeline_in_publicly_accessible_project', true],
+    ['pipeline_in_publicly_accessible_project_but_other_objects_elsewhere', false],
+    ['pipeline_in_publicly_accessible_project_but_other_objects_elsewhere', false, 'admin'],
+  ].each do |pipeline_fixture, objects_readable, user=nil|
+    test "accesse #{pipeline_fixture} in public project with objects readable=#{objects_readable} with user #{user}" do
+      pipeline = api_fixture('pipeline_instances')[pipeline_fixture]
+      page = "/pipeline_instances/#{pipeline['uuid']}"
+      if user
+        visit page_with_token user, page
+      else
+        visit page
+      end
+
+      click_link 'foo'  # click job link
+
+      if objects_readable or (!objects_readable and user)
+        assert_text 'This pipeline was created from'
+        assert_no_text 'Output data not available'
+        assert_selector 'a', pipeline['components']['foo']['job']['uuid']
+        assert_selector 'a[href="#Log"]', text: 'Log'
+        assert_no_selector 'a[data-toggle="disabled"]', text: 'Log'
+      else
+        assert_no_text 'This pipeline was created from' # template not readable
+        assert_text 'Output data not available'
+        assert_no_selector 'a', text: pipeline['components']['foo']['job']['uuid']
+        assert_text pipeline['job']
+        assert_selector 'a[href="#Log"]', text: 'Log'
+        assert_selector 'a[data-toggle="disabled"]', text: 'Log'
+      end
+
+      click_link 'Log'
+      if objects_readable or user
+        assert_no_text 'foo'  # should be in Log tab
+        assert_text 'stderr crunchstat'  # log line
+      else
+        assert_text 'foo'     # Log tab disabled and hence still in Components tab
+        assert_no_text 'stderr crunchstat'  # log line shouldn't be seen
+      end
+    end
+  end
 end