X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/13efb6304b9fcbe0fd3b496c751184c7aa1cc4d0..43036ec0489dff57d62e67dfeeaf58ce6dae35f6:/apps/workbench/test/integration/projects_test.rb diff --git a/apps/workbench/test/integration/projects_test.rb b/apps/workbench/test/integration/projects_test.rb index b439b8a28c..ac00b1b548 100644 --- a/apps/workbench/test/integration/projects_test.rb +++ b/apps/workbench/test/integration/projects_test.rb @@ -3,15 +3,19 @@ require 'selenium-webdriver' require 'headless' class ProjectsTest < ActionDispatch::IntegrationTest - reset_api_fixtures :after_suite - setup do - Capybara.current_driver = Capybara.javascript_driver + headless = Headless.new + headless.start + Capybara.current_driver = :selenium + + # project tests need bigger page size to be able to see all the buttons + Capybara.current_session.driver.browser.manage.window.resize_to(1152, 768) end test 'Check collection count for A Project in the tab pane titles' do project_uuid = api_fixture('groups')['aproject']['uuid'] visit page_with_token 'active', '/projects/' + project_uuid + wait_for_ajax collection_count = page.all("[data-pk*='collection']").count assert_selector '#Data_collections-tab span', text: "(#{collection_count})" end @@ -223,7 +227,9 @@ class ProjectsTest < ActionDispatch::IntegrationTest assert(has_link?("Write"), "failed to change access level on new share") click_on "Revoke" + page.driver.browser.switch_to.alert.accept end + wait_for_ajax using_wait_time(Capybara.default_wait_time * 3) do assert(page.has_no_text?(name), "new share row still exists after being revoked") @@ -279,7 +285,7 @@ class ProjectsTest < ActionDispatch::IntegrationTest ['Remove',api_fixture('collections')['collection_in_aproject_with_same_name_as_in_home_project'], api_fixture('groups')['aproject'],nil,true], ].each do |action, my_collection, src, dest=nil, expect_name_change=nil| - test "selection #{action} #{expect_name_change} for project" do + test "selection #{action} -> #{expect_name_change.inspect} for project" do perform_selection_action src, dest, my_collection, action case action @@ -290,8 +296,6 @@ class ProjectsTest < ActionDispatch::IntegrationTest find(".dropdown-menu a", text: dest['name']).click assert page.has_text?(my_collection['name']), 'Collection not found in dest project after copy' - # now remove it from destination project to restore to original state - perform_selection_action dest, nil, my_collection, 'Remove' when 'Move' assert page.has_no_text?(my_collection['name']), 'Collection still found in src project after move' visit page_with_token 'active', '/' @@ -299,8 +303,6 @@ class ProjectsTest < ActionDispatch::IntegrationTest find(".dropdown-menu a", text: dest['name']).click assert page.has_text?(my_collection['name']), 'Collection not found in dest project after move' - # move it back to src project to restore to original state - perform_selection_action dest, src, my_collection, action when 'Remove' assert page.has_no_text?(my_collection['name']), 'Collection still found in src project after remove' visit page_with_token 'active', '/' @@ -325,7 +327,7 @@ class ProjectsTest < ActionDispatch::IntegrationTest find('input[type=checkbox]').click end - click_button 'Selection...' + click_button 'Selection' within('.selection-action-container') do assert page.has_text?("Compare selected"), "Compare selected link text not found" @@ -357,7 +359,7 @@ class ProjectsTest < ActionDispatch::IntegrationTest find("#projects-menu").click find(".dropdown-menu a", text: my_project['name']).click - click_button 'Selection...' + click_button 'Selection' within('.selection-action-container') do page.assert_selector 'li.disabled', text: 'Create new collection with selected collections' page.assert_selector 'li.disabled', text: 'Compare selected' @@ -376,7 +378,7 @@ class ProjectsTest < ActionDispatch::IntegrationTest find('input[type=checkbox]').click end - click_button 'Selection...' + click_button 'Selection' within('.selection-action-container') do page.assert_no_selector 'li.disabled', text: 'Create new collection with selected collections' page.assert_selector 'li', text: 'Create new collection with selected collections' @@ -401,7 +403,7 @@ class ProjectsTest < ActionDispatch::IntegrationTest find('input[type=checkbox]').click end - click_button 'Selection...' + click_button 'Selection' within('.selection-action-container') do page.assert_selector 'li.disabled', text: 'Create new collection with selected collections' page.assert_selector 'li.disabled', text: 'Compare selected' @@ -431,7 +433,7 @@ class ProjectsTest < ActionDispatch::IntegrationTest find('input[type=checkbox]').click end - click_button 'Selection...' + click_button 'Selection' within('.selection-action-container') do page.assert_selector 'li.disabled', text: 'Create new collection with selected collections' page.assert_selector 'li.disabled', text: 'Compare selected' @@ -443,6 +445,21 @@ class ProjectsTest < ActionDispatch::IntegrationTest end end + # "Remove selected" selection option should not be available when current user cannot write to the project + test "remove selected action is not available when current user cannot write to project" do + my_project = api_fixture('groups')['anonymously_accessible_project'] + visit page_with_token 'active', "/projects/#{my_project['uuid']}" + + click_button 'Selection' + within('.selection-action-container') do + assert_selector 'li', text: 'Create new collection with selected collections' + assert_selector 'li', text: 'Compare selected' + assert_selector 'li', text: 'Copy selected' + assert_selector 'li', text: 'Move selected' + assert_no_selector 'li', text: 'Remove selected' + end + end + [ ['active', true], ['project_viewer', false], @@ -460,7 +477,7 @@ class ProjectsTest < ActionDispatch::IntegrationTest find('input[type=checkbox]').click end - click_button 'Selection...' + click_button 'Selection' within('.selection-action-container') do click_link 'Create new collection with selected collections' end @@ -494,10 +511,6 @@ class ProjectsTest < ActionDispatch::IntegrationTest item_list_parameter, sorted = false, sort_parameters = nil) - headless = Headless.new - headless.start - Capybara.current_driver = :selenium - project_uuid = api_fixture('groups')[project_name]['uuid'] visit page_with_token 'user1_with_load', '/projects/' + project_uuid @@ -635,4 +648,27 @@ class ProjectsTest < ActionDispatch::IntegrationTest end end + test "error while loading tab" do + original_arvados_v1_base = Rails.configuration.arvados_v1_base + + visit page_with_token 'active', '/projects/' + api_fixture('groups')['aproject']['uuid'] + + # Point to a bad api server url to generate error + Rails.configuration.arvados_v1_base = "https://[100::f]:1/" + click_link 'Other objects' + within '#Other_objects' do + # Error + assert_selector('a', text: 'Reload tab') + + # Now point back to the orig api server and reload tab + Rails.configuration.arvados_v1_base = original_arvados_v1_base + click_link 'Reload tab' + assert_no_selector('a', text: 'Reload tab') + assert_selector('button', text: 'Selection') + within '.selection-action-container' do + assert_selector 'tr[data-kind="arvados#trait"]' + end + end + end + end