X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/76eaaac9fed4e74b8073ee08f99b84fc7922ac9f..b01138f2ed3b666fd6075a6d77caddb5d5ca91e1:/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 00a25ba456..80e6a71932 100644 --- a/apps/workbench/test/integration/users_test.rb +++ b/apps/workbench/test/integration/users_test.rb @@ -1,19 +1,16 @@ require 'integration_helper' -require 'selenium-webdriver' -require 'headless' class UsersTest < ActionDispatch::IntegrationTest - reset_api_fixtures :after_suite test "login as active user but not admin" do - Capybara.current_driver = Capybara.javascript_driver + need_javascript visit page_with_token('active_trustedclient') assert page.has_no_link? 'Users' 'Found Users link for non-admin user' end test "login as admin user and verify active user data" do - Capybara.current_driver = Capybara.javascript_driver + need_javascript visit page_with_token('admin_trustedclient') # go to Users list page @@ -45,10 +42,7 @@ class UsersTest < ActionDispatch::IntegrationTest end test "create a new user" do - headless = Headless.new - headless.start - - Capybara.current_driver = :selenium + need_javascript visit page_with_token('admin_trustedclient') @@ -89,15 +83,10 @@ class UsersTest < ActionDispatch::IntegrationTest click_link 'Metadata' assert page.has_text? 'Repository: test_repo' assert !(page.has_text? 'VirtualMachine:') - - headless.stop end test "setup the active user" do - headless = Headless.new - headless.start - - Capybara.current_driver = :selenium + need_javascript visit page_with_token('admin_trustedclient') find('#system-menu').click @@ -146,15 +135,10 @@ class UsersTest < ActionDispatch::IntegrationTest click_link 'Metadata' assert page.has_text? 'Repository: second_test_repo' assert page.has_text? 'VirtualMachine: testvm.shell' - - headless.stop end test "unsetup active user" do - headless = Headless.new - headless.start - - Capybara.current_driver = :selenium + need_javascript visit page_with_token('admin_trustedclient') @@ -181,11 +165,15 @@ class UsersTest < ActionDispatch::IntegrationTest # unsetup user and verify all the above links are deleted click_link 'Admin' click_button 'Deactivate Active User' - sleep(0.1) - # Should now be back in the Attributes tab for the user - page.driver.browser.switch_to.alert.accept + if Capybara.current_driver == :selenium + sleep(0.1) + page.driver.browser.switch_to.alert.accept + else + # poltergeist returns true for confirm(), so we don't need to accept. + end + # 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 assert_equal "false", text, "Expected user's is_active to be false after unsetup" @@ -214,8 +202,42 @@ class UsersTest < ActionDispatch::IntegrationTest click_link 'Metadata' assert page.has_text? 'Repository: second_test_repo' assert page.has_text? 'VirtualMachine: testvm.shell' - - headless.stop 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 + end + end end