X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/29a1b2c8894db8e6c6b840220b45371c521a17d2..111c659adefb766d3773e48ae839515f8007f67c:/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 c461d3ff4b..e6eaa7f67f 100644 --- a/apps/workbench/test/integration/projects_test.rb +++ b/apps/workbench/test/integration/projects_test.rb @@ -1,5 +1,6 @@ require 'integration_helper' require 'helpers/share_object_helper' +require_relative 'integration_test_utils' class ProjectsTest < ActionDispatch::IntegrationTest include ShareObjectHelper @@ -35,109 +36,6 @@ 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 @@ -201,12 +99,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(" ") @@ -722,4 +614,111 @@ class ProjectsTest < ActionDispatch::IntegrationTest find("#page-wrapper .nav-tabs :first-child a").click assert_text("Collection modified at") end + + # "Select all" and "Unselect all" options + test "select all and unselect all actions" do + need_selenium 'to check and uncheck checkboxes' + + visit page_with_token 'active', '/projects/' + api_fixture('groups')['aproject']['uuid'] + + # Go to "Data collections" tab and click on "Select all" + click_link 'Data collections' + wait_for_ajax + + # Initially, all selection options for this tab should be disabled + click_button 'Selection' + within('.selection-action-container') do + assert_selector 'li.disabled', text: 'Create new collection with selected collections' + assert_selector 'li.disabled', text: 'Copy selected' + end + + # Select all + click_button 'Select all' + + assert_checkboxes_state('input[type=checkbox]', true, '"select all" should check all checkboxes') + + # Now the selection options should be enabled + click_button 'Selection' + within('.selection-action-container') do + assert_selector 'li', text: 'Create new collection with selected collections' + assert_no_selector 'li.disabled', text: 'Copy selected' + assert_selector 'li', text: 'Create new collection with selected collections' + assert_no_selector 'li.disabled', text: 'Copy selected' + end + + # Go to Jobs and pipelines tab and assert none selected + click_link 'Jobs and pipelines' + wait_for_ajax + + # Since this is the first visit to this tab, all selection options should be disabled + click_button 'Selection' + within('.selection-action-container') do + assert_selector 'li.disabled', text: 'Create new collection with selected collections' + assert_selector 'li.disabled', text: 'Copy selected' + end + + assert_checkboxes_state('input[type=checkbox]', false, '"select all" should check all checkboxes') + + # Select all + click_button 'Select all' + assert_checkboxes_state('input[type=checkbox]', true, '"select all" should check all checkboxes') + + # Applicable selection options should be enabled + click_button 'Selection' + within('.selection-action-container') do + assert_selector 'li.disabled', text: 'Create new collection with selected collections' + assert_selector 'li', text: 'Copy selected' + assert_no_selector 'li.disabled', text: 'Copy selected' + end + + # Unselect all + click_button 'Unselect all' + assert_checkboxes_state('input[type=checkbox]', false, '"select all" should check all checkboxes') + + # All selection options should be disabled again + click_button 'Selection' + within('.selection-action-container') do + assert_selector 'li.disabled', text: 'Create new collection with selected collections' + assert_selector 'li.disabled', text: 'Copy selected' + end + + # Go back to Data collections tab and verify all are still selected + click_link 'Data collections' + wait_for_ajax + + # Selection options should be enabled based on the fact that all collections are still selected in this tab + click_button 'Selection' + within('.selection-action-container') do + assert_selector 'li', text: 'Create new collection with selected collections' + assert_no_selector 'li.disabled', text: 'Copy selected' + assert_selector 'li', text: 'Create new collection with selected collections' + assert_no_selector 'li.disabled', text: 'Copy selected' + end + + assert_checkboxes_state('input[type=checkbox]', true, '"select all" should check all checkboxes') + + # Unselect all + find('button#unselect-all').click + assert_checkboxes_state('input[type=checkbox]', false, '"unselect all" should clear all checkboxes') + + # Now all selection options should be disabled because none of the collections are checked + click_button 'Selection' + within('.selection-action-container') do + assert_selector 'li.disabled', text: 'Copy selected' + assert_selector 'li.disabled', text: 'Copy selected' + end + + # Verify checking just one checkbox still works as expected + within('tr', text: api_fixture('collections')['collection_to_move_around_in_aproject']['name']) do + find('input[type=checkbox]').click + end + + click_button 'Selection' + within('.selection-action-container') do + assert_selector 'li', text: 'Create new collection with selected collections' + assert_no_selector 'li.disabled', text: 'Copy selected' + assert_selector 'li', text: 'Create new collection with selected collections' + assert_no_selector 'li.disabled', text: 'Copy selected' + end + end end