X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/b3e2782f72e0ca381f3f8c508227ebd7a2ef0c92..7407f41105f8000bb3908d41a31daaf3a30d9440:/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 9c2842f1c2..7a5103007f 100644 --- a/apps/workbench/test/integration/projects_test.rb +++ b/apps/workbench/test/integration/projects_test.rb @@ -1,3 +1,7 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 + require 'integration_helper' require 'helpers/share_object_helper' require_relative 'integration_test_utils' @@ -36,113 +40,13 @@ class ProjectsTest < ActionDispatch::IntegrationTest "Description update did not survive page refresh") end - test 'Find a project and edit description to textile description' do - visit page_with_token 'active', '/' - find("#projects-menu").click - find(".dropdown-menu a", text: "A Project").click - within('.container-fluid', text: api_fixture('groups')['aproject']['name']) do - find('span', text: api_fixture('groups')['aproject']['name']).click - within('.arv-description-as-subtitle') do - find('.fa-pencil').click - find('.editable-input textarea').set('

*Textile description for A project* - "take me home":/

And a new paragraph in description.

') - find('.editable-submit').click - end - wait_for_ajax - end - - # visit project page - visit current_path - assert_no_text '*Textile description for A project*' - assert(find?('.container-fluid', text: 'Textile description for A project'), - "Description update did not survive page refresh") - assert(find?('.container-fluid', text: 'And a new paragraph in description'), - "Description did not contain the expected new paragraph") - assert(page.has_link?("take me home"), "link not found in description") - - click_link 'take me home' - - # now in dashboard - assert(page.has_text?('Active pipelines'), 'Active pipelines - not found on dashboard') - end - - test 'Find a project and edit description to html description' do - visit page_with_token 'active', '/' - find("#projects-menu").click - find(".dropdown-menu a", text: "A Project").click - within('.container-fluid', text: api_fixture('groups')['aproject']['name']) do - find('span', text: api_fixture('groups')['aproject']['name']).click - within('.arv-description-as-subtitle') do - find('.fa-pencil').click - find('.editable-input textarea').set('
Textile description for A project
- take me home') - find('.editable-submit').click - end - wait_for_ajax - end - visit current_path - assert(find?('.container-fluid', text: 'Textile description for A project'), - "Description update did not survive page refresh") - assert(!find?('.container-fluid', text: '
Textile description for A project
'), - "Textile description is displayed with uninterpreted formatting characters") - assert(page.has_link?("take me home"),"link not found in description") - click_link 'take me home' - assert page.has_text?('Active pipelines') - end - - test 'Find a project and edit description to textile description with link to object' do - visit page_with_token 'active', '/' - find("#projects-menu").click - find(".dropdown-menu a", text: "A Project").click - within('.container-fluid', text: api_fixture('groups')['aproject']['name']) do - find('span', text: api_fixture('groups')['aproject']['name']).click - within('.arv-description-as-subtitle') do - find('.fa-pencil').click - find('.editable-input textarea').set('*Textile description for A project* - "go to sub-project":' + api_fixture('groups')['asubproject']['uuid'] + "'") - find('.editable-submit').click - end - wait_for_ajax - end - visit current_path - assert(find?('.container-fluid', text: 'Textile description for A project'), - "Description update did not survive page refresh") - assert(!find?('.container-fluid', text: '*Textile description for A project*'), - "Textile description is displayed with uninterpreted formatting characters") - assert(page.has_link?("go to sub-project"), "link not found in description") - click_link 'go to sub-project' - assert(page.has_text?(api_fixture('groups')['asubproject']['name']), 'sub-project name not found after clicking link') - end - - test 'Add a new name, then edit it, without creating a duplicate' do - project_uuid = api_fixture('groups')['aproject']['uuid'] - specimen_uuid = api_fixture('traits')['owned_by_aproject_with_no_name']['uuid'] - visit page_with_token 'active', '/projects/' + project_uuid - click_link 'Other objects' - within '.selection-action-container' do - # Wait for the tab to load: - assert_selector 'tr[data-kind="arvados#trait"]' - within first('tr', text: 'Trait') do - find(".fa-pencil").click - find('.editable-input input').set('Now I have a name.') - find('.glyphicon-ok').click - assert_selector '.editable', text: 'Now I have a name.' - find(".fa-pencil").click - find('.editable-input input').set('Now I have a new name.') - find('.glyphicon-ok').click - end - wait_for_ajax - assert_selector '.editable', text: 'Now I have a new name.' - end - visit current_path - click_link 'Other objects' - within '.selection-action-container' do - find '.editable', text: 'Now I have a new name.' - assert_no_selector '.editable', text: 'Now I have a name.' - end - end - test 'Create a project and move it into a different project' do visit page_with_token 'active', '/projects' find("#projects-menu").click - find(".dropdown-menu a", text: "Home").click + within('.dropdown-menu') do + first('li', text: 'Home').click + end + wait_for_ajax find('.btn', text: "Add a subproject").click within('h2') do @@ -154,7 +58,10 @@ class ProjectsTest < ActionDispatch::IntegrationTest visit '/projects' find("#projects-menu").click - find(".dropdown-menu a", text: "Home").click + within('.dropdown-menu') do + first('li', text: 'Home').click + end + wait_for_ajax find('.btn', text: "Add a subproject").click within('h2') do find('.fa-pencil').click @@ -186,7 +93,7 @@ class ProjectsTest < ActionDispatch::IntegrationTest end test "projects not publicly sharable when anonymous browsing disabled" do - Rails.configuration.anonymous_user_token = false + Rails.configuration.Users.AnonymousUserToken = "" open_groups_sharing # Check for a group we do expect first, to make sure the modal's loaded. assert_selector(".modal-container .selectable", @@ -196,18 +103,12 @@ class ProjectsTest < ActionDispatch::IntegrationTest end test "projects publicly sharable when anonymous browsing enabled" do - Rails.configuration.anonymous_user_token = "testonlytoken" + Rails.configuration.Users.AnonymousUserToken = "testonlytoken" open_groups_sharing assert_selector(".modal-container .selectable", text: group_name("anonymous_group")) end - test "project viewer can't see project sharing tab" do - show_object_using('project_viewer', 'groups', 'aproject', 'A Project') - assert(page.has_no_link?("Sharing"), - "read-only project user sees sharing tab") - end - test "project owner can manage sharing for another user" do add_user = api_fixture('users')['future_project_user'] new_name = ["first_name", "last_name"].map { |k| add_user[k] }.join(" ") @@ -231,7 +132,7 @@ class ProjectsTest < ActionDispatch::IntegrationTest show_object_using('active', 'groups', 'aproject', 'A Project') click_on "Sharing" click_on "Share with groups" - good_uuid = api_fixture("groups")["private"]["uuid"] + good_uuid = api_fixture("groups")["future_project_viewing_group"]["uuid"] assert(page.has_selector?(".selectable[data-object-uuid=\"#{good_uuid}\"]"), "'share with groups' listing missing owned user group") bad_uuid = api_fixture("groups")["asubproject"]["uuid"] @@ -491,9 +392,7 @@ class ProjectsTest < ActionDispatch::IntegrationTest my_project = api_fixture('groups')['aproject'] my_collection = api_fixture('collections')['collection_to_move_around_in_aproject'] - visit page_with_token user, '/' - find("#projects-menu").click - find(".dropdown-menu a", text: my_project['name']).click + visit page_with_token user, "/projects/#{my_project['uuid']}" click_link 'Data collections' assert page.has_text?(my_collection['name']), 'Collection not found in project' @@ -517,18 +416,6 @@ class ProjectsTest < ActionDispatch::IntegrationTest end end - [ - ["jobs", "/jobs"], - ["pipelines", "/pipeline_instances"], - ["collections", "/collections"] - ].each do |target,path| - test "Test dashboard button all #{target}" do - visit page_with_token 'active', '/' - click_link "All #{target}" - assert_equal path, current_path - end - end - def scroll_setup(project_name, total_nbr_items, item_list_parameter, @@ -631,60 +518,40 @@ class ProjectsTest < ActionDispatch::IntegrationTest [ ['project_with_10_pipelines', 10, 0], - ['project_with_2_pipelines_and_60_jobs', 2, 60], + ['project_with_2_pipelines_and_60_crs', 2, 60], ['project_with_25_pipelines', 25, 0], - ].each do |project_name, num_pipelines, num_jobs| - test "scroll pipeline instances tab for #{project_name} with #{num_pipelines} pipelines and #{num_jobs} jobs" do - item_list_parameter = "Jobs_and_pipelines" + ].each do |project_name, num_pipelines, num_crs| + test "scroll pipeline instances tab for #{project_name} with #{num_pipelines} pipelines and #{num_crs} container requests" do + item_list_parameter = "Pipelines_and_processes" scroll_setup project_name, - num_pipelines + num_jobs, + num_pipelines + num_crs, item_list_parameter # check the general scrolling and the pipelines scroll_items_check num_pipelines, "pipeline_", item_list_parameter, 'tr[data-kind="arvados#pipelineInstance"]' - # Check job count separately - jobs_found = page.all('tr[data-kind="arvados#job"]') - found_job_count = jobs_found.count - assert_equal num_jobs, found_job_count, 'Did not find expected number of jobs' - end - end - - # Move button accessibility - [ - ['admin', true], - ['active', true], # project owner - ['project_viewer', false], - ].each do |user, can_move| - test "#{user} can move subproject under another user's Home #{can_move}" do - project = api_fixture('groups')['aproject'] - collection = api_fixture('collections')['collection_to_move_around_in_aproject'] - - # verify the project move button - visit page_with_token user, "/projects/#{project['uuid']}" - if can_move - assert page.has_link? 'Move project...' - else - assert page.has_no_link? 'Move project...' - end + # Check container request count separately + crs_found = page.all('tr[data-kind="arvados#containerRequest"]') + found_cr_count = crs_found.count + assert_equal num_crs, found_cr_count, 'Did not find expected number of container requests' end end test "error while loading tab" do - original_arvados_v1_base = Rails.configuration.arvados_v1_base + original_arvados_v1_base = Rails.configuration.Services.Controller.ExternalURL 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://[::1]:1/" + Rails.configuration.Services.Controller.ExternalURL = "https://[::1]: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 + Rails.configuration.Services.Controller.ExternalURL = original_arvados_v1_base click_link 'Reload tab' assert_no_selector('a', text: 'Reload tab') assert_selector('button', text: 'Selection') @@ -695,7 +562,6 @@ class ProjectsTest < ActionDispatch::IntegrationTest end test "add new project using projects dropdown" do - # verify that selection options are disabled on the project until an item is selected visit page_with_token 'active', '/' # Add a new project @@ -703,13 +569,6 @@ class ProjectsTest < ActionDispatch::IntegrationTest click_link 'Add a new project' assert_text 'New project' assert_text 'No description provided' - - # Add one more new project - find("#projects-menu").click - click_link 'Add a new project' - match = /New project \(\d\)/.match page.text - assert match, 'Expected project name not found' - assert_text 'No description provided' end test "first tab loads data when visiting other tab directly" do @@ -755,8 +614,8 @@ class ProjectsTest < ActionDispatch::IntegrationTest assert_no_selector 'li.disabled', text: 'Copy selected' end - # Go to Jobs and pipelines tab and assert none selected - click_link 'Jobs and pipelines' + # Go to Pipelines and processes tab and assert none selected + click_link 'Pipelines and processes' wait_for_ajax # Since this is the first visit to this tab, all selection options should be disabled @@ -830,4 +689,70 @@ class ProjectsTest < ActionDispatch::IntegrationTest assert_no_selector 'li.disabled', text: 'Copy selected' end end + + test "test search all projects menu item in projects menu" do + need_selenium + visit page_with_token('active') + find('#projects-menu').click + within('.dropdown-menu') do + assert_selector 'a', text: 'Search all projects' + find('a', text: 'Search all projects').click + end + within('.modal-content') do + assert page.has_text?('All projects'), 'No text - All projects' + assert page.has_text?('Search'), 'No text - Search' + assert page.has_text?('Cancel'), 'No text - Cancel' + fill_in "Search", with: 'Unrestricted public data' + wait_for_ajax + assert_selector 'div', text: 'Unrestricted public data' + find(:xpath, '//*[@id="choose-scroll"]/div[2]/div').click + click_button 'Show' + end + assert page.has_text?('Unrestricted public data'), 'No text - Unrestricted public data' + assert page.has_text?('An anonymously accessible project'), 'No text - An anonymously accessible project' + end + + test "test star and unstar project" do + visit page_with_token 'active', "/projects/#{api_fixture('groups')['anonymously_accessible_project']['uuid']}" + + # add to favorites + find('.fa-star-o').click + wait_for_ajax + + find("#projects-menu").click + within('.dropdown-menu') do + assert_selector 'li', text: 'Unrestricted public data' + end + + # remove from favotires + find('.fa-star').click + wait_for_ajax + + find("#projects-menu").click + within('.dropdown-menu') do + assert_no_selector 'li', text: 'Unrestricted public data' + end + end + + [ + ['Workflow with input specifications', 'this workflow has inputs specified', 'Provide a value for the following'], + ].each do |template_name, preview_txt, process_txt| + test "run a process using template #{template_name} in a project" do + project = api_fixture('groups')['aproject'] + visit page_with_token 'active', '/projects/' + project['uuid'] + + find('.btn', text: 'Run a process').click + + # in the chooser, verify preview and click Next button + within('.modal-dialog') do + find('.selectable', text: template_name).click + assert_text preview_txt + find('.btn', text: 'Next: choose inputs').click + end + + # in the process page now + assert_text process_txt + assert_text project['name'] + end + end end