Warning
This document is for an in-development version of Galaxy. You can alternatively view this page in the latest release if it exists or view the top of the latest release's documentation.
Source code for tool_shed.test.functional.test_0530_repository_admin_feature
import logging
from ..base.twilltestcase import common, ShedTwillTestCase
log = logging.getLogger(__name__)
repository_name = 'filtering_0530'
repository_description = 'Filtering repository for test 0530'
repository_long_description = 'This is the filtering repository for test 0530.'
category_name = 'Test 0530 Repository Admin Role'
category_description = 'Verify the functionality of the code that handles the repository admin role.'
'''
1. Create new repository as user user1.
2. Check to make sure a new role was created named <repo_name>_user1_admin.
3. Check to make sure a new repository_role_association record was created with appropriate repository id and role id.
4. Change the name of the repository created in step 1 - this can be done as long as the repository has not been installed or cloned.
5. Make sure the name of the role initially inspected in Step 2 has been changed to reflect the new repository name from Step 4.
6. Log into the Tool Shed as a user that is not the repository owner (e.g., user2) and make sure the repository name
and description cannot be changed.
7. As user user1, add user user2 as a repository admin user.
8. Log into the Tool Shed as user user2 and make sure the repository name and description can now be changed.
'''
[docs]class TestRepositoryAdminRole(ShedTwillTestCase):
'''Verify that the code correctly handles the repository admin role.'''
[docs] def test_0000_initiate_users(self):
"""Create necessary user accounts."""
self.login(email=common.test_user_1_email, username=common.test_user_1_name)
test_user_1 = self.test_db_util.get_user(common.test_user_1_email)
assert test_user_1 is not None, 'Problem retrieving user with email %s from the database' % common.test_user_1_email
self.test_db_util.get_private_role(test_user_1)
self.login(email=common.test_user_2_email, username=common.test_user_2_name)
test_user_2 = self.test_db_util.get_user(common.test_user_2_email)
assert test_user_2 is not None, 'Problem retrieving user with email %s from the database' % common.test_user_2_email
self.test_db_util.get_private_role(test_user_2)
self.login(email=common.admin_email, username=common.admin_username)
admin_user = self.test_db_util.get_user(common.admin_email)
assert admin_user is not None, 'Problem retrieving user with email %s from the database' % common.admin_email
self.test_db_util.get_private_role(admin_user)
[docs] def test_0005_create_filtering_repository(self):
"""Create and populate the filtering_0530 repository."""
'''
This is step 1 - Create new repository as user user1.
'''
category = self.create_category(name=category_name, description=category_description)
self.login(email=common.test_user_1_email, username=common.test_user_1_name)
repository = self.get_or_create_repository(name=repository_name,
description=repository_description,
long_description=repository_long_description,
owner=common.test_user_1_name,
category_id=self.security.encode_id(category.id),
strings_displayed=[])
self.upload_file(repository,
filename='filtering/filtering_1.1.0.tar',
filepath=None,
valid_tools_only=True,
uncompress_file=True,
remove_repo_files_not_in_tar=False,
commit_message='Uploaded filtering 1.1.0 tarball.',
strings_displayed=[],
strings_not_displayed=[])
[docs] def test_0010_verify_repository_admin_role_exists(self):
'''Verify that the role filtering_0530_user1_admin exists.'''
'''
This is step 2 - Check to make sure a new role was created named filtering_0530_user1_admin.
'''
test_user_1 = self.test_db_util.get_user(common.test_user_1_email)
repository_admin_role = self.test_db_util.get_role(test_user_1, 'filtering_0530_user1_admin')
assert repository_admin_role is not None, 'Admin role for filtering_0530 was not created.'
[docs] def test_0015_verify_repository_role_association(self):
'''Verify that the filtering_0530_user1_admin role is associated with the filtering_0530 repository.'''
'''
This is step 3 - Check to make sure a new repository_role_association record was created with appropriate repository id and role id.
'''
repository = self.test_db_util.get_repository_by_name_and_owner(repository_name, common.test_user_1_name)
test_user_1 = self.test_db_util.get_user(common.test_user_1_email)
repository_admin_role = self.test_db_util.get_role(test_user_1, 'filtering_0530_user1_admin')
repository_role_association = self.test_db_util.get_repository_role_association(repository.id, repository_admin_role.id)
assert repository_role_association is not None, 'Repository filtering_0530 is not associated with the filtering_0530_user1_admin role.'
[docs] def test_0020_rename_repository(self):
'''Rename the repository to renamed_filtering_0530.'''
'''
This is step 4 - Change the name of the repository created in step 1 - this can be done as long as the repository has not
been installed or cloned.
'''
repository = self.test_db_util.get_repository_by_name_and_owner(repository_name, common.test_user_1_name)
self.edit_repository_information(repository, revert=False, repo_name='renamed_filtering_0530')
self.test_db_util.refresh(repository)
assert repository.name == 'renamed_filtering_0530', 'Repository was not renamed to renamed_filtering_0530.'
[docs] def test_0025_check_admin_role_name(self):
return
'''Check that a role renamed_filtering_0530_user1_admin now exists, and filtering_0530_user1_admin does not.'''
'''
This is step 5 - Make sure the name of the role initially inspected in Step 2 has been changed to reflect the
new repository name from Step 4.
'''
test_user_1 = self.test_db_util.get_user(common.test_user_1_email)
old_repository_admin_role = self.test_db_util.get_role(test_user_1, 'filtering_0530_%s_admin' % test_user_1.username)
assert old_repository_admin_role is None, 'Admin role filtering_0530_user1_admin incorrectly exists.'
new_repository_admin_role = self.test_db_util.get_role(test_user_1, 'renamed_filtering_0530_%s_admin' % test_user_1.username)
assert new_repository_admin_role is not None, 'Admin role renamed_filtering_0530_user1_admin does not exist.'
[docs] def test_0030_verify_access_denied(self):
'''Make sure a non-admin user can't modify the repository.'''
'''
This is step 6 - Log into the Tool Shed as a user that is not the repository owner (e.g., user2) and make sure the repository
name and description cannot be changed.
'''
self.login(email=common.test_user_2_email, username=common.test_user_2_name)
repository = self.test_db_util.get_repository_by_name_and_owner('renamed_filtering_0530', common.test_user_1_name)
strings_not_displayed = ['Manage repository']
strings_displayed = ['View repository']
self.display_manage_repository_page(repository, strings_not_displayed=strings_not_displayed)
self.submit_form(button='edit_repository_button', description='This description has been modified.')
strings_displayed = ['You are not the owner of this repository, so you cannot administer it.']
strings_not_displayed = ['The repository information has been updated.']
self.check_for_strings(strings_displayed=strings_displayed, strings_not_displayed=strings_not_displayed)
[docs] def test_0035_grant_admin_role(self):
'''Grant the repository admin role to user2.'''
'''
This is step 7 - As user user1, add user user2 as a repository admin user.
'''
self.login(email=common.test_user_1_email, username=common.test_user_1_name)
test_user_2 = self.test_db_util.get_user(common.test_user_2_email)
repository = self.test_db_util.get_repository_by_name_and_owner('renamed_filtering_0530', common.test_user_1_name)
self.assign_admin_role(repository, test_user_2)
[docs] def test_0040_rename_repository_as_repository_admin(self):
'''Rename the repository as user2.'''
'''
This is step 8 - Log into the Tool Shed as user user2 and make sure the repository name and description can now be changed.
'''
self.login(email=common.test_user_2_email, username=common.test_user_2_name)
repository = self.test_db_util.get_repository_by_name_and_owner('renamed_filtering_0530', common.test_user_1_name)
self.edit_repository_information(repository, revert=False, repo_name='filtering_0530')
self.test_db_util.refresh(repository)
assert repository.name == 'filtering_0530', 'User with admin role failed to rename repository.'
test_user_1 = self.test_db_util.get_user(common.test_user_1_email)
old_repository_admin_role = self.test_db_util.get_role(test_user_1, 'renamed_filtering_0530_user1_admin')
assert old_repository_admin_role is None, 'Admin role renamed_filtering_0530_user1_admin incorrectly exists.'
new_repository_admin_role = self.test_db_util.get_role(test_user_1, 'filtering_0530_user1_admin')
assert new_repository_admin_role is not None, 'Admin role filtering_0530_user1_admin does not exist.'