X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/d7e0ab968120be2807c8cc4adf41c85e887e0b05..de11b137d4469e9d54e078ac0dd5664bdb90e486:/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 838884edbf..57be9d370d 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 => "newtestrepo" click_button "Submit" wait_for_ajax end @@ -74,6 +77,8 @@ class UsersTest < ActionDispatch::IntegrationTest find('a', text: 'Show'). click + click_link 'Attributes' + assert page.has_text? 'modified_by_user_uuid' page.within(:xpath, '//span[@data-name="is_active"]') do assert_equal "false", text, "Expected new user's is_active to be false" @@ -81,8 +86,8 @@ class UsersTest < ActionDispatch::IntegrationTest click_link 'Advanced' click_link 'Metadata' - assert page.has_text? 'Repository: foo/newtestrepo' - assert !(page.has_text? 'VirtualMachine:') + assert page.has_text? 'can_read' # make sure page is rendered / ready + assert page.has_no_text? 'VirtualMachine:' end test "setup the active user" do @@ -100,45 +105,45 @@ class UsersTest < ActionDispatch::IntegrationTest # Setup user click_link 'Admin' - assert page.has_text? 'As an admin, you can setup' + assert page.has_text? 'This button sets up a user' - click_link 'Setup Active User' + click_link 'Setup account for Active User' within '.modal-content' do find 'label', text: 'Virtual Machine' - fill_in "repo_name", :with => "activetestrepo" click_button "Submit" end visit user_url + click_link 'Attributes' assert page.has_text? 'modified_by_client_uuid' click_link 'Advanced' click_link 'Metadata' - assert page.has_text? 'Repository: active/activetestrepo' 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 account for Active User' within '.modal-content' do - fill_in "repo_name", :with => "activetestrepo2" select("testvm.shell", :from => 'vm_uuid') fill_in "groups", :with => "test group one, test-group-two" click_button "Submit" end visit user_url + click_link 'Attributes' find '#Attributes', text: 'modified_by_client_uuid' click_link 'Advanced' click_link 'Metadata' - assert page.has_text? 'Repository: active/activetestrepo2' assert page.has_text? 'VirtualMachine: testvm.shell' assert page.has_text? '["test group one", "test-group-two"]' + vm_links = all("a", text: "VirtualMachine:") + assert_equal(2, vm_links.size) end test "unsetup active user" do @@ -156,7 +161,7 @@ class UsersTest < ActionDispatch::IntegrationTest user_url = page.current_url # Verify that is_active is set - find('a,button', text: 'Attributes').click + click_link 'Attributes' assert page.has_text? 'modified_by_user_uuid' page.within(:xpath, '//span[@data-name="is_active"]') do assert_equal "true", text, "Expected user's is_active to be true" @@ -177,6 +182,8 @@ class UsersTest < ActionDispatch::IntegrationTest # poltergeist returns true for confirm(), so we don't need to accept. end + click_link 'Attributes' + # Should now be back in the Attributes tab for the user assert page.has_text? 'modified_by_user_uuid' page.within(:xpath, '//span[@data-name="is_active"]') do @@ -185,62 +192,45 @@ class UsersTest < ActionDispatch::IntegrationTest click_link 'Advanced' click_link 'Metadata' - assert page.has_no_text? 'Repository: active/' 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 account for Active User' within '.modal-content' do - fill_in "repo_name", :with => "activetestrepo" select("testvm.shell", :from => 'vm_uuid') click_button "Submit" end visit user_url + click_link 'Attributes' assert page.has_text? 'modified_by_client_uuid' click_link 'Advanced' click_link 'Metadata' - assert page.has_text? 'Repository: active/activetestrepo' 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? 'This button sets up a user' + + 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