X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/d446d49dd75f14f3b454fa89190068b4e475c946..060d38d627bd1e51dd2b3c6e7de9af6aa7d7b6f3:/apps/workbench/test/integration/users_test.rb diff --git a/apps/workbench/test/integration/users_test.rb b/apps/workbench/test/integration/users_test.rb index 80e6a71932..bad01a1c62 100644 --- a/apps/workbench/test/integration/users_test.rb +++ b/apps/workbench/test/integration/users_test.rb @@ -1,3 +1,7 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 + require 'integration_helper' class UsersTest < ActionDispatch::IntegrationTest @@ -56,7 +60,6 @@ class UsersTest < ActionDispatch::IntegrationTest within '.modal-content' do find 'label', text: 'Virtual Machine' fill_in "email", :with => "foo@example.com" - fill_in "repo_name", :with => "test_repo" click_button "Submit" wait_for_ajax end @@ -81,8 +84,8 @@ class UsersTest < ActionDispatch::IntegrationTest click_link 'Advanced' click_link 'Metadata' - assert page.has_text? 'Repository: test_repo' - assert !(page.has_text? 'VirtualMachine:') + assert page.has_text? 'can_login' # make sure page is rendered / ready + assert page.has_no_text? 'VirtualMachine:' end test "setup the active user" do @@ -102,11 +105,10 @@ class UsersTest < ActionDispatch::IntegrationTest click_link 'Admin' assert page.has_text? 'As an admin, you can setup' - click_link 'Setup Active User' + click_link 'Setup shell account for Active User' within '.modal-content' do find 'label', text: 'Virtual Machine' - fill_in "repo_name", :with => "test_repo" click_button "Submit" end @@ -115,16 +117,17 @@ class UsersTest < ActionDispatch::IntegrationTest click_link 'Advanced' click_link 'Metadata' - assert page.has_text? 'Repository: test_repo' - assert !(page.has_text? 'VirtualMachine:') + vm_links = all("a", text: "VirtualMachine:") + assert_equal(1, vm_links.size) + assert_equal("VirtualMachine: testvm2.shell", vm_links.first.text) # Click on Setup button again and this time also choose a VM click_link 'Admin' - click_link 'Setup Active User' + click_link 'Setup shell account for Active User' within '.modal-content' do - fill_in "repo_name", :with => "second_test_repo" select("testvm.shell", :from => 'vm_uuid') + fill_in "groups", :with => "test group one, test-group-two" click_button "Submit" end @@ -133,8 +136,8 @@ class UsersTest < ActionDispatch::IntegrationTest click_link 'Advanced' click_link 'Metadata' - assert page.has_text? 'Repository: second_test_repo' assert page.has_text? 'VirtualMachine: testvm.shell' + assert page.has_text? '["test group one", "test-group-two"]' end test "unsetup active user" do @@ -181,16 +184,13 @@ class UsersTest < ActionDispatch::IntegrationTest click_link 'Advanced' click_link 'Metadata' - assert !(page.has_text? 'Repository: test_repo') - assert !(page.has_text? 'Repository: second_test_repo') - assert !(page.has_text? 'VirtualMachine: testvm.shell') + assert page.has_no_text? 'VirtualMachine: testvm.shell' # setup user again and verify links present click_link 'Admin' - click_link 'Setup Active User' + click_link 'Setup shell account for Active User' within '.modal-content' do - fill_in "repo_name", :with => "second_test_repo" select("testvm.shell", :from => 'vm_uuid') click_button "Submit" end @@ -200,44 +200,28 @@ class UsersTest < ActionDispatch::IntegrationTest click_link 'Advanced' click_link 'Metadata' - assert page.has_text? 'Repository: second_test_repo' assert page.has_text? 'VirtualMachine: testvm.shell' end - [ - ['admin', false], - ['active', true], - ].each do |username, expect_show_button| - test "login as #{username} and access show button #{expect_show_button}" do - need_javascript - - user = api_fixture('users', username) - - visit page_with_token(username, '/users') - - if expect_show_button - within('tr', text: user['uuid']) do - assert_text user['email'] - assert_selector 'a', text: 'Show' - find('a', text: 'Show').click - end - assert_selector 'a', 'Data collections' - else - # no 'Show' button in the admin user's own row - within('tr', text: user['uuid']) do - assert_text user['email'] - assert_no_selector 'a', text: 'Show' - end - - # but the admin user can access 'Show' button for other users - active_user = api_fixture('users', 'active') - within('tr', text: active_user['uuid']) do - assert_text active_user['email'] - assert_selector 'a', text: 'Show' - find('a', text: 'Show').click - assert_selector 'a', 'Attributes' - end - end + test "test add group button" do + need_javascript + + user_url = "/users/#{api_fixture('users')['active']['uuid']}" + visit page_with_token('admin_trustedclient', user_url) + + # Setup user + click_link 'Admin' + assert page.has_text? 'As an admin, you can setup' + + click_link 'Add new group' + + within '.modal-content' do + fill_in "group_name_input", :with => "test-group-added-in-modal" + click_button "Create" end + wait_for_ajax + + # Back in the user "Admin" tab + assert page.has_text? 'test-group-added-in-modal' end end