X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/981c7264123f24a1873f2692a72f012ac43e726b..23c44c899b783a784bd9c60e3efda63cab2f6cc8:/apps/workbench/test/integration/user_manage_account_test.rb diff --git a/apps/workbench/test/integration/user_manage_account_test.rb b/apps/workbench/test/integration/user_manage_account_test.rb index 0414f4e09d..6d680e2d67 100644 --- a/apps/workbench/test/integration/user_manage_account_test.rb +++ b/apps/workbench/test/integration/user_manage_account_test.rb @@ -72,16 +72,24 @@ class UserManageAccountTest < ActionDispatch::IntegrationTest end end + test "pipeline notification shown even though public pipelines exist" do + skip "created_by doesn't work that way" + Rails.configuration.anonymous_user_token = api_fixture('api_client_authorizations')['anonymous']['api_token'] + visit page_with_token 'job_reader' + click_link 'notifications-menu' + assert_selector 'a', text: 'Click here to learn how to run an Arvados Crunch pipeline' + end + [ - ['inactive_but_signed_user_agreement', true], - ['active', false], - ].each do |user, notifications| - test "test manage account for #{user} with notifications #{notifications}" do + ['job_reader', :ssh, :pipeline], + ['active'], + ].each do |user, *expect| + test "manage account for #{user} with notifications #{expect.inspect}" do + Rails.configuration.anonymous_user_token = false visit page_with_token(user) click_link 'notifications-menu' - if notifications + if expect.include? :ssh assert_selector('a', text: 'Click here to set up an SSH public key for use with Arvados') - assert_selector('a', text: 'Click here to learn how to run an Arvados Crunch pipeline') click_link('Click here to set up an SSH public key for use with Arvados') assert_selector('a', text: 'Add new SSH key') @@ -90,11 +98,14 @@ class UserManageAccountTest < ActionDispatch::IntegrationTest # No more SSH notification click_link 'notifications-menu' assert_no_selector('a', text: 'Click here to set up an SSH public key for use with Arvados') - assert_selector('a', text: 'Click here to learn how to run an Arvados Crunch pipeline') else assert_no_selector('a', text: 'Click here to set up an SSH public key for use with Arvados') assert_no_selector('a', text: 'Click here to learn how to run an Arvados Crunch pipeline') end + + if expect.include? :pipeline + assert_selector('a', text: 'Click here to learn how to run an Arvados Crunch pipeline') + end end end @@ -122,4 +133,52 @@ class UserManageAccountTest < ActionDispatch::IntegrationTest end end end + + test "request shell access" do + ActionMailer::Base.deliveries = [] + visit page_with_token('spectator', '/manage_account') + assert_text 'You do not have access to any virtual machines' + click_link 'Send request for shell access' + + # Button text changes to "sending...", then back to normal. In the + # test suite we can't depend on confirming the "sending..." state + # before it goes back to normal, though. + ## assert_selector 'a', text: 'Sending request...' + assert_selector 'a', text: 'Send request for shell access' + assert_text 'A request for shell access was sent' + + # verify that the email was sent + user = api_fixture('users')['spectator'] + full_name = "#{user['first_name']} #{user['last_name']}" + expected = "Shell account request from #{full_name} (#{user['email']}, #{user['uuid']})" + found_email = 0 + ActionMailer::Base.deliveries.each do |email| + if email.subject.include?(expected) + found_email += 1 + end + end + assert_equal 1, found_email, "Expected email after requesting shell access" + + # Revisit the page and verify the request sent message along with + # the request button. + within('.navbar-fixed-top') do + find('a', text: 'spectator').click + within('.dropdown-menu') do + find('a', text: 'Manage account').click + end + end + assert_text 'You do not have access to any virtual machines.' + assert_text 'A request for shell access was sent on ' + assert_selector 'a', text: 'Send request for shell access' + end + + test "create new repository" do + visit page_with_token("active_trustedclient", "/manage_account") + click_on "Add new repository" + within ".modal-dialog" do + fill_in "Name", with: "workbenchtest" + click_on "Create" + end + assert_text ":active/workbenchtest.git" + end end