- # test manage_account page
- def check_manage_account_page user
- within('.navbar-fixed-top') do
- find('a', text: "#{user['email']}").click
- within('.dropdown-menu') do
- find('a', text: 'Manage account').click
- end
- end
-
- # now in manage account page
- assert page.has_link? 'Virtual Machines'
- assert page.has_link? 'Repositories'
- assert page.has_link? 'SSH Keys'
- assert page.has_link? 'Current Token'
-
- assert page.has_text? 'The Arvados API token is a secret key that enables the Arvados SDKs to access Arvados'
-
- click_link 'Add new SSH key'
-
- within '.modal-content' do
- assert page.has_text? 'Public Key'
- assert page.has_button? 'Cancel'
- assert page.has_button? 'Submit'
-
- page.find_field('public_key').set 'first test with an incorrect ssh key value'
- click_button 'Submit'
- assert page.has_text? 'Public key does not appear to be a valid ssh-rsa or dsa public key'
-
- public_key_str = api_fixture('authorized_keys')['active']['public_key']
- page.find_field('public_key').set public_key_str
- page.find_field('name').set 'added_in_test'
- click_button 'Submit'
- assert page.has_text? 'Public key already exists in the database, use a different key.'
-
- new_key = SSHKey.generate
- page.find_field('public_key').set new_key.ssh_public_key
- page.find_field('name').set 'added_in_test'
- click_button 'Submit'
- end
-
- # key must be added. look for it in the refreshed page
- assert page.has_text? 'added_in_test'
- end
-
- # check manage profile page and add missing profile to the user
- def add_profile user
- assert page.has_no_text? 'My projects'
- assert page.has_no_text? 'Projects shared with me'
-
- assert page.has_text? 'Profile'
- assert page.has_text? 'First name'
- assert page.has_text? 'Last name'
- assert page.has_text? 'Identity URL'
- assert page.has_text? 'Email'
- assert page.has_text? user['email']
+ [
+ [nil, nil, false, false],
+ ['inactive', api_fixture('users')['inactive'], true, false],
+ ['inactive_uninvited', api_fixture('users')['inactive_uninvited'], false, false],
+ ['active', api_fixture('users')['active'], true, true],
+ ['admin', api_fixture('users')['admin'], true, true],
+ ['active_no_prefs', api_fixture('users')['active_no_prefs'], true, false],
+ ['active_no_prefs_profile', api_fixture('users')['active_no_prefs_profile'], true, false],
+ ].each do |token, user, invited, has_profile|