X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/fc2dc01f5e98b3c1d663e78f882eed20962de9d7..0eb72b526bf8bbb011551ecf019f604e17a534f1:/apps/workbench/test/integration/projects_test.rb?ds=sidebyside diff --git a/apps/workbench/test/integration/projects_test.rb b/apps/workbench/test/integration/projects_test.rb index 366b1d3ddc..ac78344ea5 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,38 +40,13 @@ class ProjectsTest < ActionDispatch::IntegrationTest "Description update did not survive page refresh") 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 @@ -79,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 @@ -127,12 +109,6 @@ class ProjectsTest < ActionDispatch::IntegrationTest 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(" ") @@ -416,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' @@ -442,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, @@ -556,43 +518,23 @@ 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 @@ -620,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 @@ -628,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 @@ -680,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 @@ -755,4 +689,71 @@ 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 + + [ + ['Two Part Pipeline Template', 'part-one', 'Provide a value for the following'], + ['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