X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/1ec89c1c31669eb89bd1997cfa9d3c50f0204dbe..0215bf7b8c61d59462a476d850af999105856177:/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 cb06e19a27..73a23d6d35 100644 --- a/apps/workbench/test/integration/projects_test.rb +++ b/apps/workbench/test/integration/projects_test.rb @@ -172,8 +172,36 @@ class ProjectsTest < ActionDispatch::IntegrationTest "Project 5678 should now be inside project 1234") end + def open_groups_sharing(project_name="aproject", token_name="active") + project = api_fixture("groups", project_name) + visit(page_with_token(token_name, "/projects/#{project['uuid']}")) + click_on "Sharing" + click_on "Share with groups" + end + + def group_name(group_key) + api_fixture("groups", group_key, "name") + end + + test "projects not publicly sharable when anonymous browsing disabled" do + Rails.configuration.anonymous_user_token = false + open_groups_sharing + # Check for a group we do expect first, to make sure the modal's loaded. + assert_selector(".modal-container .selectable", + text: group_name("all_users")) + assert_no_selector(".modal-container .selectable", + text: group_name("anonymous_group")) + end + + test "projects publicly sharable when anonymous browsing enabled" do + Rails.configuration.anonymous_user_token = "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_project_using("project_viewer") + show_object_using('project_viewer', 'groups', 'aproject', 'A Project') assert(page.has_no_link?("Sharing"), "read-only project user sees sharing tab") end @@ -182,7 +210,7 @@ class ProjectsTest < ActionDispatch::IntegrationTest add_user = api_fixture('users')['future_project_user'] new_name = ["first_name", "last_name"].map { |k| add_user[k] }.join(" ") - show_project_using("active") + show_object_using('active', 'groups', 'aproject', 'A Project') click_on "Sharing" add_share_and_check("users", new_name, add_user) modify_share_and_check(new_name) @@ -191,14 +219,14 @@ class ProjectsTest < ActionDispatch::IntegrationTest test "project owner can manage sharing for another group" do new_name = api_fixture('groups')['future_project_viewing_group']['name'] - show_project_using("active") + show_object_using('active', 'groups', 'aproject', 'A Project') click_on "Sharing" add_share_and_check("groups", new_name) modify_share_and_check(new_name) end test "'share with group' listing does not offer projects" do - show_project_using("active") + show_object_using('active', 'groups', 'aproject', 'A Project') click_on "Sharing" click_on "Share with groups" good_uuid = api_fixture("groups")["private"]["uuid"] @@ -239,14 +267,6 @@ class ProjectsTest < ActionDispatch::IntegrationTest when 'Remove' assert page.has_no_text?(my_collection['name']), 'Collection still found in src project after remove' - visit page_with_token 'active', '/' - find("#projects-menu").click - find(".dropdown-menu a", text: "Home").click - assert page.has_text?(my_collection['name']), 'Collection not found in home project after remove' - if expect_name_change - assert page.has_text?(my_collection['name']+' removed from ' + src['name']), - 'Collection with update name is not found in home project after remove' - end end end end