Merge "Stop caching client to fix long-running test fails"
This commit is contained in:
commit
80e7d569a0
@ -53,17 +53,19 @@ class BackupRunner(TestRunner):
|
||||
self, expected_exception=exceptions.BadRequest,
|
||||
expected_http_code=400):
|
||||
invalid_inst_id = 'invalid-inst-id'
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.backups.create,
|
||||
client, client.backups.create,
|
||||
self.BACKUP_NAME, invalid_inst_id, self.BACKUP_DESC)
|
||||
|
||||
def run_backup_create_instance_not_found(
|
||||
self, expected_exception=exceptions.NotFound,
|
||||
expected_http_code=404):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.backups.create,
|
||||
client, client.backups.create,
|
||||
self.BACKUP_NAME, generate_uuid(), self.BACKUP_DESC)
|
||||
|
||||
def run_add_data_for_backup(self):
|
||||
@ -147,32 +149,37 @@ class BackupRunner(TestRunner):
|
||||
def run_restore_instance_from_not_completed_backup(
|
||||
self, expected_exception=exceptions.Conflict,
|
||||
expected_http_code=409):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self._restore_from_backup, self.backup_info.id)
|
||||
None, self._restore_from_backup, client, self.backup_info.id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_instance_action_right_after_backup_create(
|
||||
self, expected_exception=exceptions.UnprocessableEntity,
|
||||
expected_http_code=422):
|
||||
client = self.auth_client
|
||||
self.assert_raises(expected_exception, expected_http_code,
|
||||
self.auth_client.instances.resize_instance,
|
||||
client, client.instances.resize_instance,
|
||||
self.instance_info.id, 1)
|
||||
|
||||
def run_backup_create_another_backup_running(
|
||||
self, expected_exception=exceptions.UnprocessableEntity,
|
||||
expected_http_code=422):
|
||||
client = self.auth_client
|
||||
self.assert_raises(expected_exception, expected_http_code,
|
||||
self.auth_client.backups.create,
|
||||
client, client.backups.create,
|
||||
'backup_test2', self.instance_info.id,
|
||||
'test description2')
|
||||
|
||||
def run_backup_delete_while_backup_running(
|
||||
self, expected_exception=exceptions.UnprocessableEntity,
|
||||
expected_http_code=422):
|
||||
result = self.auth_client.backups.list()
|
||||
client = self.auth_client
|
||||
result = client.backups.list()
|
||||
backup = result[0]
|
||||
self.assert_raises(expected_exception, expected_http_code,
|
||||
self.auth_client.backups.delete, backup.id)
|
||||
client, client.backups.delete, backup.id)
|
||||
|
||||
def run_backup_create_completed(self):
|
||||
self._verify_backup(self.backup_info.id)
|
||||
@ -226,9 +233,10 @@ class BackupRunner(TestRunner):
|
||||
def run_backup_list_filter_datastore_not_found(
|
||||
self, expected_exception=exceptions.NotFound,
|
||||
expected_http_code=404):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.backups.list,
|
||||
client, client.backups.list,
|
||||
datastore='NOT_FOUND')
|
||||
|
||||
def run_backup_list_for_instance(self):
|
||||
@ -255,12 +263,10 @@ class BackupRunner(TestRunner):
|
||||
def run_backup_get_unauthorized_user(
|
||||
self, expected_exception=exceptions.NotFound,
|
||||
expected_http_code=404):
|
||||
client = self.unauth_client
|
||||
self.assert_raises(
|
||||
expected_exception, None,
|
||||
self.unauth_client.backups.get, self.backup_info.id)
|
||||
# we're using a different client, so we'll check the return code
|
||||
# on it explicitly, instead of depending on 'assert_raises'
|
||||
self.assert_client_code(expected_http_code, client=self.unauth_client)
|
||||
expected_exception, expected_http_code,
|
||||
client, client.backups.get, self.backup_info.id)
|
||||
|
||||
def run_add_data_for_inc_backup_1(self):
|
||||
self.backup_host = self.get_instance_host()
|
||||
@ -302,15 +308,16 @@ class BackupRunner(TestRunner):
|
||||
|
||||
def assert_restore_from_backup(self, backup_ref, suffix='',
|
||||
expected_http_code=200):
|
||||
result = self._restore_from_backup(backup_ref, suffix=suffix)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
client = self.auth_client
|
||||
result = self._restore_from_backup(client, backup_ref, suffix=suffix)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_equal('BUILD', result.status,
|
||||
'Unexpected instance status')
|
||||
return result.id
|
||||
|
||||
def _restore_from_backup(self, backup_ref, suffix=''):
|
||||
def _restore_from_backup(self, client, backup_ref, suffix=''):
|
||||
restore_point = {'backupRef': backup_ref}
|
||||
result = self.auth_client.instances.create(
|
||||
result = client.instances.create(
|
||||
self.instance_info.name + '_restore' + suffix,
|
||||
self.instance_info.dbaas_flavor_href,
|
||||
self.instance_info.volume,
|
||||
@ -372,8 +379,9 @@ class BackupRunner(TestRunner):
|
||||
|
||||
def assert_delete_restored_instance(
|
||||
self, instance_id, expected_http_code):
|
||||
self.auth_client.instances.delete(instance_id)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
client = self.auth_client
|
||||
client.instances.delete(instance_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_delete_restored_inc_1_instance(self, expected_http_code=202):
|
||||
self.assert_delete_restored_instance(
|
||||
@ -398,20 +406,19 @@ class BackupRunner(TestRunner):
|
||||
def run_delete_unknown_backup(
|
||||
self, expected_exception=exceptions.NotFound,
|
||||
expected_http_code=404):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.backups.delete,
|
||||
client, client.backups.delete,
|
||||
'unknown_backup')
|
||||
|
||||
def run_delete_backup_unauthorized_user(
|
||||
self, expected_exception=exceptions.NotFound,
|
||||
expected_http_code=404):
|
||||
client = self.unauth_client
|
||||
self.assert_raises(
|
||||
expected_exception, None,
|
||||
self.unauth_client.backups.delete, self.backup_info.id)
|
||||
# we're using a different client, so we'll check the return code
|
||||
# on it explicitly, instead of depending on 'assert_raises'
|
||||
self.assert_client_code(expected_http_code, client=self.unauth_client)
|
||||
expected_exception, expected_http_code,
|
||||
client, client.backups.delete, self.backup_info.id)
|
||||
|
||||
def run_delete_inc_2_backup(self, expected_http_code=202):
|
||||
self.assert_delete_backup(
|
||||
@ -420,14 +427,15 @@ class BackupRunner(TestRunner):
|
||||
|
||||
def assert_delete_backup(
|
||||
self, backup_id, expected_http_code):
|
||||
self.auth_client.backups.delete(backup_id)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
self._wait_until_backup_is_gone(backup_id)
|
||||
client = self.auth_client
|
||||
client.backups.delete(backup_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self._wait_until_backup_is_gone(client, backup_id)
|
||||
|
||||
def _wait_until_backup_is_gone(self, backup_id):
|
||||
def _wait_until_backup_is_gone(self, client, backup_id):
|
||||
def _backup_is_gone():
|
||||
try:
|
||||
self.auth_client.backups.get(backup_id)
|
||||
client.backups.get(backup_id)
|
||||
return False
|
||||
except exceptions.NotFound:
|
||||
return True
|
||||
@ -443,9 +451,10 @@ class BackupRunner(TestRunner):
|
||||
expected_http_code=404):
|
||||
if self.backup_inc_1_info is None:
|
||||
raise SkipTest("Incremental Backup not created")
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.backups.get,
|
||||
client, client.backups.get,
|
||||
self.backup_inc_1_info.id)
|
||||
self.backup_inc_1_info = None
|
||||
|
||||
|
@ -49,9 +49,10 @@ class ConfigurationRunner(TestRunner):
|
||||
def assert_action_on_conf_group_failure(
|
||||
self, group_values, expected_exception, expected_http_code):
|
||||
json_def = json.dumps(group_values)
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.configurations.create,
|
||||
client, client.configurations.create,
|
||||
'conf_group',
|
||||
json_def,
|
||||
'Group with Bad or Invalid entries',
|
||||
@ -128,13 +129,14 @@ class ConfigurationRunner(TestRunner):
|
||||
def assert_create_group(self, name, description, values,
|
||||
expected_http_code):
|
||||
json_def = json.dumps(values)
|
||||
result = self.auth_client.configurations.create(
|
||||
client = self.auth_client
|
||||
result = client.configurations.create(
|
||||
name,
|
||||
json_def,
|
||||
description,
|
||||
datastore=self.instance_info.dbaas_datastore,
|
||||
datastore_version=self.instance_info.dbaas_datastore_version)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
with TypeCheck('Configuration', result) as configuration:
|
||||
configuration.has_field('name', basestring)
|
||||
@ -269,12 +271,10 @@ class ConfigurationRunner(TestRunner):
|
||||
def assert_conf_get_unauthorized_user(
|
||||
self, config_id, expected_exception=exceptions.NotFound,
|
||||
expected_http_code=404):
|
||||
client = self.unauth_client
|
||||
self.assert_raises(
|
||||
expected_exception, None,
|
||||
self.unauth_client.configurations.get, config_id)
|
||||
# we're using a different client, so we'll check the return code
|
||||
# on it explicitly, instead of depending on 'assert_raises'
|
||||
self.assert_client_code(expected_http_code, client=self.unauth_client)
|
||||
expected_exception, expected_http_code,
|
||||
client, client.configurations.get, config_id)
|
||||
|
||||
def run_non_dynamic_conf_get_unauthorized_user(
|
||||
self, expected_exception=exceptions.NotFound,
|
||||
@ -372,9 +372,10 @@ class ConfigurationRunner(TestRunner):
|
||||
def assert_update_group(
|
||||
self, instance_id, group_id, values,
|
||||
expected_states, expected_http_code, restart_inst=False):
|
||||
self.auth_client.configurations.update(group_id, values)
|
||||
self.assert_instance_action(
|
||||
instance_id, expected_states, expected_http_code)
|
||||
client = self.auth_client
|
||||
client.configurations.update(group_id, values)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_instance_action(instance_id, expected_states)
|
||||
if restart_inst:
|
||||
self._restart_instance(instance_id)
|
||||
|
||||
@ -445,9 +446,10 @@ class ConfigurationRunner(TestRunner):
|
||||
def assert_instance_modify(
|
||||
self, instance_id, group_id, expected_states, expected_http_code,
|
||||
restart_inst=False):
|
||||
self.auth_client.instances.modify(instance_id, configuration=group_id)
|
||||
self.assert_instance_action(
|
||||
instance_id, expected_states, expected_http_code)
|
||||
client = self.auth_client
|
||||
client.instances.modify(instance_id, configuration=group_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_instance_action(instance_id, expected_states)
|
||||
|
||||
# Verify the group has been attached.
|
||||
instance = self.get_instance(instance_id)
|
||||
@ -470,9 +472,10 @@ class ConfigurationRunner(TestRunner):
|
||||
def assert_instance_modify_failure(
|
||||
self, instance_id, group_id, expected_exception,
|
||||
expected_http_code):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.instances.modify,
|
||||
client, client.instances.modify,
|
||||
instance_id, configuration=group_id)
|
||||
|
||||
def run_delete_dynamic_group(self, expected_http_code=202):
|
||||
@ -481,8 +484,9 @@ class ConfigurationRunner(TestRunner):
|
||||
expected_http_code)
|
||||
|
||||
def assert_group_delete(self, group_id, expected_http_code):
|
||||
self.auth_client.configurations.delete(group_id)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
client = self.auth_client
|
||||
client.configurations.delete(group_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_delete_non_dynamic_group(self, expected_http_code=202):
|
||||
if self.non_dynamic_group_id:
|
||||
@ -491,16 +495,18 @@ class ConfigurationRunner(TestRunner):
|
||||
|
||||
def assert_group_delete_failure(self, group_id, expected_exception,
|
||||
expected_http_code):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.configurations.delete, group_id)
|
||||
client, client.configurations.delete, group_id)
|
||||
|
||||
def _restart_instance(
|
||||
self, instance_id, expected_states=['REBOOT', 'ACTIVE'],
|
||||
expected_http_code=202):
|
||||
self.auth_client.instances.restart(instance_id)
|
||||
self.assert_instance_action(instance_id, expected_states,
|
||||
expected_http_code)
|
||||
client = self.auth_client
|
||||
client.instances.restart(instance_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_instance_action(instance_id, expected_states)
|
||||
|
||||
def run_create_instance_with_conf(self):
|
||||
self.config_id_for_inst = (
|
||||
@ -514,7 +520,8 @@ class ConfigurationRunner(TestRunner):
|
||||
|
||||
def assert_create_instance_with_conf(self, config_id):
|
||||
# test that a new instance will apply the configuration on create
|
||||
result = self.auth_client.instances.create(
|
||||
client = self.auth_client
|
||||
result = client.instances.create(
|
||||
self.instance_info.name + "_config",
|
||||
self.instance_info.dbaas_flavor_href,
|
||||
self.instance_info.volume,
|
||||
@ -524,7 +531,7 @@ class ConfigurationRunner(TestRunner):
|
||||
nics=self.instance_info.nics,
|
||||
availability_zone="nova",
|
||||
configuration=config_id)
|
||||
self.assert_client_code(200, client=self.auth_client)
|
||||
self.assert_client_code(client, 200)
|
||||
self.assert_equal("BUILD", result.status, 'Unexpected inst status')
|
||||
return result.id
|
||||
|
||||
@ -554,8 +561,9 @@ class ConfigurationRunner(TestRunner):
|
||||
raise SkipTest("No instance created with a configuration group.")
|
||||
|
||||
def assert_delete_conf_instance(self, instance_id, expected_http_code):
|
||||
self.auth_client.instances.delete(instance_id)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
client = self.auth_client
|
||||
client.instances.delete(instance_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_wait_for_delete_conf_instance(
|
||||
self, expected_last_state=['SHUTDOWN']):
|
||||
|
@ -52,9 +52,11 @@ class DatabaseActionsRunner(TestRunner):
|
||||
|
||||
def assert_databases_create(self, instance_id, serial_databases_def,
|
||||
expected_http_code):
|
||||
self.auth_client.databases.create(instance_id, serial_databases_def)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
self.wait_for_database_create(instance_id, serial_databases_def)
|
||||
client = self.auth_client
|
||||
client.databases.create(instance_id, serial_databases_def)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.wait_for_database_create(client,
|
||||
instance_id, serial_databases_def)
|
||||
return serial_databases_def
|
||||
|
||||
def run_databases_list(self, expected_http_code=200):
|
||||
@ -63,8 +65,9 @@ class DatabaseActionsRunner(TestRunner):
|
||||
|
||||
def assert_databases_list(self, instance_id, expected_database_defs,
|
||||
expected_http_code, limit=2):
|
||||
full_list = self.auth_client.databases.list(instance_id)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
client = self.auth_client
|
||||
full_list = client.databases.list(instance_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
listed_databases = {database.name: database for database in full_list}
|
||||
self.assert_is_none(full_list.next,
|
||||
"Unexpected pagination in the list.")
|
||||
@ -85,8 +88,8 @@ class DatabaseActionsRunner(TestRunner):
|
||||
"output.")
|
||||
|
||||
# Test list pagination.
|
||||
list_page = self.auth_client.databases.list(instance_id, limit=limit)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
list_page = client.databases.list(instance_id, limit=limit)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
self.assert_true(len(list_page) <= limit)
|
||||
if len(full_list) > limit:
|
||||
@ -102,10 +105,9 @@ class DatabaseActionsRunner(TestRunner):
|
||||
self.assert_equal(expected_marker, marker,
|
||||
"Pagination marker should be the last element "
|
||||
"in the page.")
|
||||
list_page = self.auth_client.databases.list(
|
||||
list_page = client.databases.list(
|
||||
instance_id, marker=marker)
|
||||
self.assert_client_code(expected_http_code,
|
||||
client=self.auth_client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_pagination_match(
|
||||
list_page, full_list, limit, len(full_list))
|
||||
|
||||
@ -132,10 +134,11 @@ class DatabaseActionsRunner(TestRunner):
|
||||
def assert_databases_create_failure(
|
||||
self, instance_id, serial_databases_def,
|
||||
expected_exception, expected_http_code):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception,
|
||||
expected_http_code,
|
||||
self.auth_client.databases.create,
|
||||
client, client.databases.create,
|
||||
instance_id,
|
||||
serial_databases_def)
|
||||
|
||||
@ -163,16 +166,18 @@ class DatabaseActionsRunner(TestRunner):
|
||||
instance_id,
|
||||
database_name,
|
||||
expected_http_code):
|
||||
self.auth_client.databases.delete(instance_id, database_name)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
self._wait_for_database_delete(instance_id, database_name)
|
||||
client = self.auth_client
|
||||
client.databases.delete(instance_id, database_name)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self._wait_for_database_delete(client, instance_id, database_name)
|
||||
|
||||
def _wait_for_database_delete(self, instance_id, deleted_database_name):
|
||||
def _wait_for_database_delete(self, client,
|
||||
instance_id, deleted_database_name):
|
||||
self.report.log("Waiting for deleted database to disappear from the "
|
||||
"listing: %s" % deleted_database_name)
|
||||
|
||||
def _db_is_gone():
|
||||
all_dbs = self.get_db_names(instance_id)
|
||||
all_dbs = self.get_db_names(client, instance_id)
|
||||
return deleted_database_name not in all_dbs
|
||||
|
||||
try:
|
||||
@ -205,8 +210,9 @@ class DatabaseActionsRunner(TestRunner):
|
||||
def assert_database_delete_failure(
|
||||
self, instance_id, database_name,
|
||||
expected_exception, expected_http_code):
|
||||
client = self.auth_client
|
||||
self.assert_raises(expected_exception, expected_http_code,
|
||||
self.auth_client.databases.delete,
|
||||
client, client.databases.delete,
|
||||
instance_id, database_name)
|
||||
|
||||
def get_system_databases(self):
|
||||
|
@ -101,7 +101,7 @@ class GuestLogRunner(TestRunner):
|
||||
self.report.log("Executing log_show for log '%s'" % log_name)
|
||||
log_details = client.instances.log_show(
|
||||
self.instance_info.id, log_name)
|
||||
self.assert_client_code(expected_http_code, client=client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_log_details(
|
||||
log_details, log_name,
|
||||
expected_type=expected_type,
|
||||
@ -187,7 +187,7 @@ class GuestLogRunner(TestRunner):
|
||||
self.report.log("Executing log_enable for log '%s'" % log_name)
|
||||
log_details = client.instances.log_enable(
|
||||
self.instance_info.id, log_name)
|
||||
self.assert_client_code(expected_http_code, client=client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_log_details(
|
||||
log_details, log_name,
|
||||
expected_type=expected_type,
|
||||
@ -204,7 +204,7 @@ class GuestLogRunner(TestRunner):
|
||||
(log_name, discard))
|
||||
log_details = client.instances.log_disable(
|
||||
self.instance_info.id, log_name, discard=discard)
|
||||
self.assert_client_code(expected_http_code, client=client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_log_details(
|
||||
log_details, log_name,
|
||||
expected_type=expected_type,
|
||||
@ -222,7 +222,7 @@ class GuestLogRunner(TestRunner):
|
||||
(log_name, disable, discard))
|
||||
log_details = client.instances.log_publish(
|
||||
self.instance_info.id, log_name, disable=disable, discard=discard)
|
||||
self.assert_client_code(expected_http_code, client=client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_log_details(
|
||||
log_details, log_name,
|
||||
expected_type=expected_type,
|
||||
@ -238,7 +238,7 @@ class GuestLogRunner(TestRunner):
|
||||
self.report.log("Executing log_discard for log '%s'" % log_name)
|
||||
log_details = client.instances.log_discard(
|
||||
self.instance_info.id, log_name)
|
||||
self.assert_client_code(expected_http_code, client=client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_log_details(
|
||||
log_details, log_name,
|
||||
expected_type=expected_type,
|
||||
@ -303,10 +303,10 @@ class GuestLogRunner(TestRunner):
|
||||
expected_exception, expected_http_code,
|
||||
log_name):
|
||||
self.assert_raises(expected_exception, None,
|
||||
client.instances.log_enable,
|
||||
client, client.instances.log_enable,
|
||||
self.instance_info.id, log_name)
|
||||
# we may not be using the main client, so check explicitly here
|
||||
self.assert_client_code(expected_http_code, client=client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_test_log_disable_sys(self,
|
||||
expected_exception=exceptions.BadRequest,
|
||||
@ -320,11 +320,11 @@ class GuestLogRunner(TestRunner):
|
||||
expected_exception, expected_http_code,
|
||||
log_name, discard=None):
|
||||
self.assert_raises(expected_exception, None,
|
||||
client.instances.log_disable,
|
||||
client, client.instances.log_disable,
|
||||
self.instance_info.id, log_name,
|
||||
discard=discard)
|
||||
# we may not be using the main client, so check explicitly here
|
||||
self.assert_client_code(expected_http_code, client=client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_test_log_show_unauth_user(self,
|
||||
expected_exception=exceptions.NotFound,
|
||||
@ -338,19 +338,18 @@ class GuestLogRunner(TestRunner):
|
||||
expected_exception, expected_http_code,
|
||||
log_name):
|
||||
self.assert_raises(expected_exception, None,
|
||||
client.instances.log_show,
|
||||
client, client.instances.log_show,
|
||||
self.instance_info.id, log_name)
|
||||
# we may not be using the main client, so check explicitly here
|
||||
self.assert_client_code(expected_http_code, client=client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_test_log_list_unauth_user(self,
|
||||
expected_exception=exceptions.NotFound,
|
||||
expected_http_code=404):
|
||||
self.assert_raises(expected_exception, None,
|
||||
self.unauth_client.instances.log_list,
|
||||
client = self.unauth_client
|
||||
self.assert_raises(expected_exception, expected_http_code,
|
||||
client, client.instances.log_list,
|
||||
self.instance_info.id)
|
||||
# we're not using the main client, so check explicitly here
|
||||
self.assert_client_code(expected_http_code, client=self.unauth_client)
|
||||
|
||||
def run_test_log_generator_unauth_user(self):
|
||||
self.assert_log_generator_unauth_user(
|
||||
@ -406,11 +405,11 @@ class GuestLogRunner(TestRunner):
|
||||
log_name,
|
||||
disable=None, discard=None):
|
||||
self.assert_raises(expected_exception, None,
|
||||
client.instances.log_publish,
|
||||
client, client.instances.log_publish,
|
||||
self.instance_info.id, log_name,
|
||||
disable=disable, discard=discard)
|
||||
# we may not be using the main client, so check explicitly here
|
||||
self.assert_client_code(expected_http_code, client=client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_test_log_discard_unexposed_user(
|
||||
self, expected_exception=exceptions.BadRequest,
|
||||
@ -423,11 +422,9 @@ class GuestLogRunner(TestRunner):
|
||||
def assert_log_discard_fails(self, client,
|
||||
expected_exception, expected_http_code,
|
||||
log_name):
|
||||
self.assert_raises(expected_exception, None,
|
||||
client.instances.log_discard,
|
||||
self.assert_raises(expected_exception, expected_http_code,
|
||||
client, client.instances.log_discard,
|
||||
self.instance_info.id, log_name)
|
||||
# we may not be using the main client, so check explicitly here
|
||||
self.assert_client_code(expected_http_code, client=client)
|
||||
|
||||
def run_test_log_enable_user(self):
|
||||
expected_status = guest_log.LogStatus.Ready.name
|
||||
@ -470,15 +467,14 @@ class GuestLogRunner(TestRunner):
|
||||
# we need to wait until the heartbeat flips the instance
|
||||
# back into 'ACTIVE' before we issue the restart command
|
||||
expected_states = ['RESTART_REQUIRED', 'ACTIVE']
|
||||
self.assert_instance_action(instance_id, expected_states, None)
|
||||
self.auth_client.instances.restart(instance_id)
|
||||
self.assert_client_code(expected_http_code,
|
||||
client=self.auth_client)
|
||||
self.assert_instance_action(instance_id, expected_states)
|
||||
client = self.auth_client
|
||||
client.instances.restart(instance_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_test_wait_for_restart(self, expected_states=['REBOOT', 'ACTIVE']):
|
||||
if self.test_helper.log_enable_requires_restart():
|
||||
self.assert_instance_action(self.instance_info.id,
|
||||
expected_states, None)
|
||||
self.assert_instance_action(self.instance_info.id, expected_states)
|
||||
|
||||
def run_test_log_publish_user(self):
|
||||
for log_name in self._get_exposed_user_log_names():
|
||||
|
@ -59,9 +59,10 @@ class InstanceActionsRunner(TestRunner):
|
||||
expected_http_code):
|
||||
self.report.log("Testing restart on instance: %s" % instance_id)
|
||||
|
||||
self.auth_client.instances.restart(instance_id)
|
||||
self.assert_instance_action(instance_id, expected_states,
|
||||
expected_http_code)
|
||||
client = self.auth_client
|
||||
client.instances.restart(instance_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_instance_action(instance_id, expected_states)
|
||||
|
||||
def run_instance_resize_volume(
|
||||
self, resize_amount=1,
|
||||
@ -83,9 +84,10 @@ class InstanceActionsRunner(TestRunner):
|
||||
old_volume_size = int(instance.volume['size'])
|
||||
new_volume_size = old_volume_size + resize_amount
|
||||
|
||||
self.auth_client.instances.resize_volume(instance_id, new_volume_size)
|
||||
self.assert_instance_action(instance_id, expected_states,
|
||||
expected_http_code)
|
||||
client = self.auth_client
|
||||
client.instances.resize_volume(instance_id, new_volume_size)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_instance_action(instance_id, expected_states)
|
||||
|
||||
instance = self.get_instance(instance_id)
|
||||
self.assert_equal(new_volume_size, instance.volume['size'],
|
||||
@ -99,9 +101,9 @@ class InstanceActionsRunner(TestRunner):
|
||||
expected_http_code):
|
||||
self.report.log("Testing resize to '%s' on instance: %s" %
|
||||
(resize_flavor_id, instance_id))
|
||||
self.auth_client.instances.resize_instance(
|
||||
instance_id, resize_flavor_id)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
client = self.auth_client
|
||||
client.instances.resize_instance(instance_id, resize_flavor_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_wait_for_instance_resize_flavor(
|
||||
self, expected_states=['RESIZE', 'ACTIVE']):
|
||||
|
@ -69,14 +69,14 @@ class InstanceCreateRunner(TestRunner):
|
||||
values = dynamic_config or non_dynamic_config
|
||||
if values:
|
||||
json_def = json.dumps(values)
|
||||
result = self.auth_client.configurations.create(
|
||||
client = self.auth_client
|
||||
result = client.configurations.create(
|
||||
'initial_configuration_for_instance_create',
|
||||
json_def,
|
||||
"Configuration group used by instance create tests.",
|
||||
datastore=self.instance_info.dbaas_datastore,
|
||||
datastore_version=self.instance_info.dbaas_datastore_version)
|
||||
self.assert_client_code(expected_http_code,
|
||||
client=self.auth_client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
self.config_group_id = result.id
|
||||
else:
|
||||
@ -184,7 +184,8 @@ class InstanceCreateRunner(TestRunner):
|
||||
instance_info.name = instance.name
|
||||
else:
|
||||
self.report.log("Creating a new instance.")
|
||||
instance = self.auth_client.instances.create(
|
||||
client = self.auth_client
|
||||
instance = client.instances.create(
|
||||
instance_info.name,
|
||||
instance_info.dbaas_flavor_href,
|
||||
instance_info.volume,
|
||||
@ -196,8 +197,8 @@ class InstanceCreateRunner(TestRunner):
|
||||
datastore=instance_info.dbaas_datastore,
|
||||
datastore_version=instance_info.dbaas_datastore_version,
|
||||
locality=locality)
|
||||
self.assert_instance_action(
|
||||
instance.id, expected_states[0:1], expected_http_code)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_instance_action(instance.id, expected_states[0:1])
|
||||
|
||||
instance_info.id = instance.id
|
||||
|
||||
@ -246,11 +247,12 @@ class InstanceCreateRunner(TestRunner):
|
||||
def wait_for_test_helpers(self, inst_info):
|
||||
self.report.log("Waiting for helper users and databases to be "
|
||||
"created on instance: %s" % inst_info.id)
|
||||
client = self.auth_client
|
||||
if inst_info.helper_user:
|
||||
self.wait_for_user_create(inst_info.id,
|
||||
self.wait_for_user_create(client, inst_info.id,
|
||||
[inst_info.helper_user])
|
||||
if inst_info.helper_database:
|
||||
self.wait_for_database_create(inst_info.id,
|
||||
self.wait_for_database_create(client, inst_info.id,
|
||||
[inst_info.helper_database])
|
||||
self.report.log("Test helpers are ready.")
|
||||
|
||||
@ -299,13 +301,15 @@ class InstanceCreateRunner(TestRunner):
|
||||
"No configuration group expected")
|
||||
|
||||
def assert_database_list(self, instance_id, expected_databases):
|
||||
self.wait_for_database_create(instance_id, expected_databases)
|
||||
self.wait_for_database_create(self.auth_client,
|
||||
instance_id, expected_databases)
|
||||
|
||||
def _get_names(self, definitions):
|
||||
return [item['name'] for item in definitions]
|
||||
|
||||
def assert_user_list(self, instance_id, expected_users):
|
||||
self.wait_for_user_create(instance_id, expected_users)
|
||||
self.wait_for_user_create(self.auth_client,
|
||||
instance_id, expected_users)
|
||||
# Verify that user definitions include only created databases.
|
||||
all_databases = self._get_names(
|
||||
self.test_helper.get_valid_database_definitions())
|
||||
@ -318,9 +322,9 @@ class InstanceCreateRunner(TestRunner):
|
||||
|
||||
def run_initialized_instance_delete(self, expected_http_code=202):
|
||||
if self.init_inst_info:
|
||||
self.auth_client.instances.delete(self.init_inst_info.id)
|
||||
self.assert_client_code(expected_http_code,
|
||||
client=self.auth_client)
|
||||
client = self.auth_client
|
||||
client.instances.delete(self.init_inst_info.id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
else:
|
||||
raise SkipTest("Cleanup is not required.")
|
||||
|
||||
@ -341,9 +345,9 @@ class InstanceCreateRunner(TestRunner):
|
||||
|
||||
def run_initial_configuration_delete(self, expected_http_code=202):
|
||||
if self.config_group_id:
|
||||
self.auth_client.configurations.delete(self.config_group_id)
|
||||
self.assert_client_code(expected_http_code,
|
||||
client=self.auth_client)
|
||||
client = self.auth_client
|
||||
client.configurations.delete(self.config_group_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
else:
|
||||
raise SkipTest("Cleanup is not required.")
|
||||
self.config_group_id = None
|
||||
|
@ -35,8 +35,9 @@ class InstanceDeleteRunner(TestRunner):
|
||||
def assert_instance_delete(self, instance_id, expected_http_code):
|
||||
self.report.log("Testing delete on instance: %s" % instance_id)
|
||||
|
||||
self.auth_client.instances.delete(instance_id)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
client = self.auth_client
|
||||
client.instances.delete(instance_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_instance_delete_wait(self, expected_states=['SHUTDOWN']):
|
||||
if self.has_do_not_delete_instance:
|
||||
|
@ -33,14 +33,15 @@ class InstanceErrorCreateRunner(TestRunner):
|
||||
name = self.instance_info.name + '_error'
|
||||
flavor = self.get_instance_flavor(fault_num=1)
|
||||
|
||||
inst = self.auth_client.instances.create(
|
||||
client = self.auth_client
|
||||
inst = client.instances.create(
|
||||
name,
|
||||
self.get_flavor_href(flavor),
|
||||
self.instance_info.volume,
|
||||
nics=self.instance_info.nics,
|
||||
datastore=self.instance_info.dbaas_datastore,
|
||||
datastore_version=self.instance_info.dbaas_datastore_version)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.error_inst_id = inst.id
|
||||
|
||||
def run_create_error2_instance(self, expected_http_code=200):
|
||||
@ -50,14 +51,15 @@ class InstanceErrorCreateRunner(TestRunner):
|
||||
name = self.instance_info.name + '_error2'
|
||||
flavor = self.get_instance_flavor(fault_num=2)
|
||||
|
||||
inst = self.auth_client.instances.create(
|
||||
client = self.auth_client
|
||||
inst = client.instances.create(
|
||||
name,
|
||||
self.get_flavor_href(flavor),
|
||||
self.instance_info.volume,
|
||||
nics=self.instance_info.nics,
|
||||
datastore=self.instance_info.dbaas_datastore,
|
||||
datastore_version=self.instance_info.dbaas_datastore_version)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.error2_inst_id = inst.id
|
||||
|
||||
def run_wait_for_error_instances(self, expected_states=['ERROR']):
|
||||
@ -100,14 +102,13 @@ class InstanceErrorCreateRunner(TestRunner):
|
||||
(instance.fault['message'], err_msg))
|
||||
|
||||
def run_delete_error_instances(self, expected_http_code=202):
|
||||
client = self.auth_client
|
||||
if self.error_inst_id:
|
||||
self.auth_client.instances.delete(self.error_inst_id)
|
||||
self.assert_client_code(expected_http_code,
|
||||
client=self.auth_client)
|
||||
client.instances.delete(self.error_inst_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
if self.error2_inst_id:
|
||||
self.auth_client.instances.delete(self.error2_inst_id)
|
||||
self.assert_client_code(expected_http_code,
|
||||
client=self.auth_client)
|
||||
client.instances.delete(self.error2_inst_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_wait_for_error_delete(self, expected_states=['SHUTDOWN']):
|
||||
delete_ids = []
|
||||
|
@ -33,22 +33,23 @@ class InstanceForceDeleteRunner(TestRunner):
|
||||
name = self.instance_info.name + '_build'
|
||||
flavor = self.get_instance_flavor()
|
||||
|
||||
inst = self.auth_client.instances.create(
|
||||
client = self.auth_client
|
||||
inst = client.instances.create(
|
||||
name,
|
||||
self.get_flavor_href(flavor),
|
||||
self.instance_info.volume,
|
||||
nics=self.instance_info.nics,
|
||||
datastore=self.instance_info.dbaas_datastore,
|
||||
datastore_version=self.instance_info.dbaas_datastore_version)
|
||||
self.assert_instance_action([inst.id], expected_states,
|
||||
expected_http_code)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_instance_action([inst.id], expected_states)
|
||||
self.build_inst_id = inst.id
|
||||
|
||||
def run_delete_build_instance(self, expected_http_code=202):
|
||||
if self.build_inst_id:
|
||||
self.admin_client.instances.force_delete(self.build_inst_id)
|
||||
self.assert_client_code(expected_http_code,
|
||||
client=self.admin_client)
|
||||
client = self.admin_client
|
||||
client.instances.force_delete(self.build_inst_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_wait_for_force_delete(self):
|
||||
if self.build_inst_id:
|
||||
|
@ -41,6 +41,7 @@ class InstanceUpgradeRunner(TestRunner):
|
||||
self.report.log("Testing upgrade on instance: %s" % instance_id)
|
||||
|
||||
target_version = self.instance_info.dbaas_datastore_version
|
||||
self.auth_client.instances.upgrade(instance_id, target_version)
|
||||
self.assert_instance_action(instance_id, expected_states,
|
||||
expected_http_code)
|
||||
client = self.auth_client
|
||||
client.instances.upgrade(instance_id, target_version)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_instance_action(instance_id, expected_states)
|
||||
|
@ -142,53 +142,59 @@ class ModuleRunner(TestRunner):
|
||||
def run_module_create_bad_type(
|
||||
self, expected_exception=exceptions.NotFound,
|
||||
expected_http_code=404):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.create,
|
||||
client, client.modules.create,
|
||||
self.MODULE_NAME, 'invalid-type', self.MODULE_NEG_CONTENTS)
|
||||
|
||||
def run_module_create_non_admin_auto(
|
||||
self, expected_exception=exceptions.Forbidden,
|
||||
expected_http_code=403):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.create,
|
||||
client, client.modules.create,
|
||||
self.MODULE_NAME, self.module_type, self.MODULE_NEG_CONTENTS,
|
||||
auto_apply=True)
|
||||
|
||||
def run_module_create_non_admin_all_tenant(
|
||||
self, expected_exception=exceptions.Forbidden,
|
||||
expected_http_code=403):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.create,
|
||||
client, client.modules.create,
|
||||
self.MODULE_NAME, self.module_type, self.MODULE_NEG_CONTENTS,
|
||||
all_tenants=True)
|
||||
|
||||
def run_module_create_non_admin_hidden(
|
||||
self, expected_exception=exceptions.Forbidden,
|
||||
expected_http_code=403):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.create,
|
||||
client, client.modules.create,
|
||||
self.MODULE_NAME, self.module_type, self.MODULE_NEG_CONTENTS,
|
||||
visible=False)
|
||||
|
||||
def run_module_create_bad_datastore(
|
||||
self, expected_exception=exceptions.NotFound,
|
||||
expected_http_code=404):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.create,
|
||||
client, client.modules.create,
|
||||
self.MODULE_NAME, self.module_type, self.MODULE_NEG_CONTENTS,
|
||||
datastore='bad-datastore')
|
||||
|
||||
def run_module_create_bad_datastore_version(
|
||||
self, expected_exception=exceptions.BadRequest,
|
||||
expected_http_code=400):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.create,
|
||||
client, client.modules.create,
|
||||
self.MODULE_NAME, self.module_type, self.MODULE_NEG_CONTENTS,
|
||||
datastore=self.instance_info.dbaas_datastore,
|
||||
datastore_version='bad-datastore-version')
|
||||
@ -196,9 +202,10 @@ class ModuleRunner(TestRunner):
|
||||
def run_module_create_missing_datastore(
|
||||
self, expected_exception=exceptions.BadRequest,
|
||||
expected_http_code=400):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.create,
|
||||
client, client.modules.create,
|
||||
self.MODULE_NAME, self.module_type, self.MODULE_NEG_CONTENTS,
|
||||
datastore_version=self.instance_info.dbaas_datastore_version)
|
||||
|
||||
@ -242,8 +249,9 @@ class ModuleRunner(TestRunner):
|
||||
datastore=datastore, datastore_version=datastore_version,
|
||||
auto_apply=auto_apply,
|
||||
live_update=live_update, visible=visible)
|
||||
if (client == self.auth_client or
|
||||
(client == self.admin_client and visible)):
|
||||
username = client.real_client.client.username
|
||||
if (('alt' in username and 'admin' not in username) or
|
||||
('admin' in username and visible)):
|
||||
self.module_create_count += 1
|
||||
if datastore:
|
||||
self.module_ds_create_count += 1
|
||||
@ -358,17 +366,19 @@ class ModuleRunner(TestRunner):
|
||||
def run_module_create_dupe(
|
||||
self, expected_exception=exceptions.BadRequest,
|
||||
expected_http_code=400):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.create,
|
||||
client, client.modules.create,
|
||||
self.MODULE_NAME, self.module_type, self.MODULE_NEG_CONTENTS)
|
||||
|
||||
def run_module_update_missing_datastore(
|
||||
self, expected_exception=exceptions.BadRequest,
|
||||
expected_http_code=400):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.update,
|
||||
client, client.modules.update,
|
||||
self.update_test_module.id,
|
||||
datastore_version=self.instance_info.dbaas_datastore_version)
|
||||
|
||||
@ -414,12 +424,10 @@ class ModuleRunner(TestRunner):
|
||||
def run_module_show_unauth_user(
|
||||
self, expected_exception=exceptions.NotFound,
|
||||
expected_http_code=404):
|
||||
client = self.unauth_client
|
||||
self.assert_raises(
|
||||
expected_exception, None,
|
||||
self.unauth_client.modules.get, self.main_test_module.id)
|
||||
# we're using a different client, so we'll check the return code
|
||||
# on it explicitly, instead of depending on 'assert_raises'
|
||||
self.assert_client_code(expected_http_code, client=self.unauth_client)
|
||||
expected_exception, expected_http_code,
|
||||
client, client.modules.get, self.main_test_module.id)
|
||||
|
||||
def run_module_list(self):
|
||||
self.assert_module_list(
|
||||
@ -551,9 +559,10 @@ class ModuleRunner(TestRunner):
|
||||
self, expected_exception=exceptions.NotFound,
|
||||
expected_http_code=404):
|
||||
module = self._find_invisible_module()
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.get, module.id)
|
||||
client, client.modules.get, module.id)
|
||||
|
||||
def run_module_list_admin(self):
|
||||
self.assert_module_list(
|
||||
@ -632,82 +641,92 @@ class ModuleRunner(TestRunner):
|
||||
def run_module_update_unauth(
|
||||
self, expected_exception=exceptions.NotFound,
|
||||
expected_http_code=404):
|
||||
client = self.unauth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.unauth_client.modules.update,
|
||||
client, client.modules.update,
|
||||
self.main_test_module.id, description='Upd')
|
||||
|
||||
def run_module_update_non_admin_auto(
|
||||
self, expected_exception=exceptions.Forbidden,
|
||||
expected_http_code=403):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.update,
|
||||
client, client.modules.update,
|
||||
self.main_test_module.id, visible=False)
|
||||
|
||||
def run_module_update_non_admin_auto_off(
|
||||
self, expected_exception=exceptions.Forbidden,
|
||||
expected_http_code=403):
|
||||
module = self._find_auto_apply_module()
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.update, module.id, auto_apply=False)
|
||||
client, client.modules.update, module.id, auto_apply=False)
|
||||
|
||||
def run_module_update_non_admin_auto_any(
|
||||
self, expected_exception=exceptions.Forbidden,
|
||||
expected_http_code=403):
|
||||
module = self._find_auto_apply_module()
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.update, module.id, description='Upd')
|
||||
client, client.modules.update, module.id, description='Upd')
|
||||
|
||||
def run_module_update_non_admin_all_tenant(
|
||||
self, expected_exception=exceptions.Forbidden,
|
||||
expected_http_code=403):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.update,
|
||||
client, client.modules.update,
|
||||
self.main_test_module.id, all_tenants=True)
|
||||
|
||||
def run_module_update_non_admin_all_tenant_off(
|
||||
self, expected_exception=exceptions.Forbidden,
|
||||
expected_http_code=403):
|
||||
module = self._find_all_tenant_module()
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.update, module.id, all_tenants=False)
|
||||
client, client.modules.update, module.id, all_tenants=False)
|
||||
|
||||
def run_module_update_non_admin_all_tenant_any(
|
||||
self, expected_exception=exceptions.Forbidden,
|
||||
expected_http_code=403):
|
||||
module = self._find_all_tenant_module()
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.update, module.id, description='Upd')
|
||||
client, client.modules.update, module.id, description='Upd')
|
||||
|
||||
def run_module_update_non_admin_invisible(
|
||||
self, expected_exception=exceptions.Forbidden,
|
||||
expected_http_code=403):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.update,
|
||||
client, client.modules.update,
|
||||
self.main_test_module.id, visible=False)
|
||||
|
||||
def run_module_update_non_admin_invisible_off(
|
||||
self, expected_exception=exceptions.NotFound,
|
||||
expected_http_code=404):
|
||||
module = self._find_invisible_module()
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.update, module.id, visible=True)
|
||||
client, client.modules.update, module.id, visible=True)
|
||||
|
||||
def run_module_update_non_admin_invisible_any(
|
||||
self, expected_exception=exceptions.NotFound,
|
||||
expected_http_code=404):
|
||||
module = self._find_invisible_module()
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.update, module.id, description='Upd')
|
||||
client, client.modules.update, module.id, description='Upd')
|
||||
|
||||
# ModuleInstanceGroup methods
|
||||
def run_module_list_instance_empty(self):
|
||||
@ -718,7 +737,7 @@ class ModuleRunner(TestRunner):
|
||||
def assert_module_list_instance(self, client, instance_id, expected_count,
|
||||
expected_http_code=200):
|
||||
module_list = client.instances.modules(instance_id)
|
||||
self.assert_client_code(expected_http_code, client=client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
count = len(module_list)
|
||||
self.assert_equal(expected_count, count,
|
||||
"Wrong number of modules from list instance")
|
||||
@ -733,7 +752,7 @@ class ModuleRunner(TestRunner):
|
||||
def assert_module_instances(self, client, module_id, expected_count,
|
||||
expected_http_code=200):
|
||||
instance_list = client.modules.instances(module_id)
|
||||
self.assert_client_code(expected_http_code, client=client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
count = len(instance_list)
|
||||
self.assert_equal(expected_count, count,
|
||||
"Wrong number of instances applied from module")
|
||||
@ -751,7 +770,7 @@ class ModuleRunner(TestRunner):
|
||||
def assert_module_query(self, client, instance_id, expected_count,
|
||||
expected_http_code=200, expected_results=None):
|
||||
modquery_list = client.instances.module_query(instance_id)
|
||||
self.assert_client_code(expected_http_code, client=client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
count = len(modquery_list)
|
||||
self.assert_equal(expected_count, count,
|
||||
"Wrong number of modules from query")
|
||||
@ -774,7 +793,7 @@ class ModuleRunner(TestRunner):
|
||||
expected_http_code=200):
|
||||
module_apply_list = client.instances.module_apply(
|
||||
instance_id, [module.id])
|
||||
self.assert_client_code(expected_http_code, client=client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
admin_only = (not module.visible or module.auto_apply or
|
||||
not module.tenant_id)
|
||||
expected_status = expected_status or 'OK'
|
||||
@ -919,7 +938,8 @@ class ModuleRunner(TestRunner):
|
||||
|
||||
def assert_inst_mod_create(self, module_id, name_suffix,
|
||||
expected_http_code):
|
||||
inst = self.auth_client.instances.create(
|
||||
client = self.auth_client
|
||||
inst = client.instances.create(
|
||||
self.instance_info.name + name_suffix,
|
||||
self.instance_info.dbaas_flavor_href,
|
||||
self.instance_info.volume,
|
||||
@ -928,15 +948,16 @@ class ModuleRunner(TestRunner):
|
||||
nics=self.instance_info.nics,
|
||||
modules=[module_id],
|
||||
)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
return inst.id
|
||||
|
||||
def run_module_delete_applied(
|
||||
self, expected_exception=exceptions.Forbidden,
|
||||
expected_http_code=403):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.delete, self.main_test_module.id)
|
||||
client, client.modules.delete, self.main_test_module.id)
|
||||
|
||||
def run_module_remove(self):
|
||||
self.assert_module_remove(self.auth_client, self.instance_info.id,
|
||||
@ -945,10 +966,10 @@ class ModuleRunner(TestRunner):
|
||||
def assert_module_remove(self, client, instance_id, module_id,
|
||||
expected_http_code=200):
|
||||
client.instances.module_remove(instance_id, module_id)
|
||||
self.assert_client_code(expected_http_code, client=client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_wait_for_inst_with_mods(self, expected_states=['BUILD', 'ACTIVE']):
|
||||
self.assert_instance_action(self.mod_inst_id, expected_states, None)
|
||||
self.assert_instance_action(self.mod_inst_id, expected_states)
|
||||
|
||||
def run_module_query_after_inst_create(self):
|
||||
auto_modules = self._find_all_auto_apply_modules(visible=True)
|
||||
@ -975,7 +996,7 @@ class ModuleRunner(TestRunner):
|
||||
prefix = 'contents'
|
||||
modretrieve_list = client.instances.module_retrieve(
|
||||
instance_id, directory=temp_dir, prefix=prefix)
|
||||
self.assert_client_code(expected_http_code, client=client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
count = len(modretrieve_list)
|
||||
self.assert_equal(expected_count, count,
|
||||
"Wrong number of modules from retrieve")
|
||||
@ -1027,16 +1048,18 @@ class ModuleRunner(TestRunner):
|
||||
self, expected_exception=exceptions.Forbidden,
|
||||
expected_http_code=403):
|
||||
module = self._find_auto_apply_module()
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.delete, module.id)
|
||||
client, client.modules.delete, module.id)
|
||||
|
||||
def run_delete_inst_with_mods(self, expected_http_code=202):
|
||||
self.assert_delete_instance(self.mod_inst_id, expected_http_code)
|
||||
|
||||
def assert_delete_instance(self, instance_id, expected_http_code):
|
||||
self.auth_client.instances.delete(instance_id)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
client = self.auth_client
|
||||
client.instances.delete(instance_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_wait_for_delete_inst_with_mods(
|
||||
self, expected_last_state=['SHUTDOWN']):
|
||||
@ -1046,40 +1069,45 @@ class ModuleRunner(TestRunner):
|
||||
def run_module_delete_non_existent(
|
||||
self, expected_exception=exceptions.NotFound,
|
||||
expected_http_code=404):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.delete, 'bad_id')
|
||||
client, client.modules.delete, 'bad_id')
|
||||
|
||||
def run_module_delete_unauth_user(
|
||||
self, expected_exception=exceptions.NotFound,
|
||||
expected_http_code=404):
|
||||
client = self.unauth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.unauth_client.modules.delete, self.main_test_module.id)
|
||||
client, client.modules.delete, self.main_test_module.id)
|
||||
|
||||
def run_module_delete_hidden_by_non_admin(
|
||||
self, expected_exception=exceptions.NotFound,
|
||||
expected_http_code=404):
|
||||
module = self._find_invisible_module()
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.delete, module.id)
|
||||
client, client.modules.delete, module.id)
|
||||
|
||||
def run_module_delete_all_tenant_by_non_admin(
|
||||
self, expected_exception=exceptions.Forbidden,
|
||||
expected_http_code=403):
|
||||
module = self._find_all_tenant_module()
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.delete, module.id)
|
||||
client, client.modules.delete, module.id)
|
||||
|
||||
def run_module_delete_auto_by_non_admin(
|
||||
self, expected_exception=exceptions.Forbidden,
|
||||
expected_http_code=403):
|
||||
module = self._find_auto_apply_module()
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.modules.delete, module.id)
|
||||
client, client.modules.delete, module.id)
|
||||
|
||||
def run_module_delete(self):
|
||||
expected_count = len(self.auth_client.modules.list()) - 1
|
||||
|
@ -60,8 +60,9 @@ class NegativeClusterActionsRunner(TestRunner):
|
||||
|
||||
def _assert_cluster_create_raises(self, cluster_name, instances_def,
|
||||
expected_http_code):
|
||||
client = self.auth_client
|
||||
self.assert_raises(exceptions.BadRequest, expected_http_code,
|
||||
self.auth_client.clusters.create,
|
||||
client, client.clusters.create,
|
||||
cluster_name,
|
||||
self.instance_info.dbaas_datastore,
|
||||
self.instance_info.dbaas_datastore_version,
|
||||
|
@ -62,7 +62,8 @@ class ReplicationRunner(TestRunner):
|
||||
self.test_helper.verify_data(data_type, host)
|
||||
|
||||
def run_create_non_affinity_master(self, expected_http_code=200):
|
||||
self.non_affinity_master_id = self.auth_client.instances.create(
|
||||
client = self.auth_client
|
||||
self.non_affinity_master_id = client.instances.create(
|
||||
self.instance_info.name + '_non-affinity',
|
||||
self.instance_info.dbaas_flavor_href,
|
||||
self.instance_info.volume,
|
||||
@ -70,7 +71,7 @@ class ReplicationRunner(TestRunner):
|
||||
datastore_version=self.instance_info.dbaas_datastore_version,
|
||||
nics=self.instance_info.nics,
|
||||
locality='anti-affinity').id
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_create_single_replica(self, expected_http_code=200):
|
||||
self.master_backup_count = len(
|
||||
@ -80,7 +81,8 @@ class ReplicationRunner(TestRunner):
|
||||
|
||||
def assert_replica_create(
|
||||
self, master_id, replica_name, replica_count, expected_http_code):
|
||||
replica = self.auth_client.instances.create(
|
||||
client = self.auth_client
|
||||
replica = client.instances.create(
|
||||
self.instance_info.name + '_' + replica_name,
|
||||
self.instance_info.dbaas_flavor_href,
|
||||
self.instance_info.volume, replica_of=master_id,
|
||||
@ -88,7 +90,7 @@ class ReplicationRunner(TestRunner):
|
||||
datastore_version=self.instance_info.dbaas_datastore_version,
|
||||
nics=self.instance_info.nics,
|
||||
replica_count=replica_count)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
return replica.id
|
||||
|
||||
def run_wait_for_single_replica(self, expected_states=['BUILD', 'ACTIVE']):
|
||||
@ -99,8 +101,9 @@ class ReplicationRunner(TestRunner):
|
||||
self.replica_1_host = self.get_instance_host(self.replica_1_id)
|
||||
|
||||
def _assert_is_master(self, instance_id, replica_ids):
|
||||
instance = self.get_instance(instance_id, client=self.admin_client)
|
||||
self.assert_client_code(200, client=self.admin_client)
|
||||
client = self.admin_client
|
||||
instance = self.get_instance(instance_id, client=client)
|
||||
self.assert_client_code(client, 200)
|
||||
CheckInstance(instance._info).slaves()
|
||||
self.assert_true(
|
||||
set(replica_ids).issubset(self._get_replica_set(instance_id)))
|
||||
@ -111,8 +114,9 @@ class ReplicationRunner(TestRunner):
|
||||
return set([replica['id'] for replica in instance._info['replicas']])
|
||||
|
||||
def _assert_is_replica(self, instance_id, master_id):
|
||||
instance = self.get_instance(instance_id, client=self.admin_client)
|
||||
self.assert_client_code(200, client=self.admin_client)
|
||||
client = self.admin_client
|
||||
instance = self.get_instance(instance_id, client=client)
|
||||
self.assert_client_code(client, 200)
|
||||
CheckInstance(instance._info).replica_of()
|
||||
self.assert_equal(master_id, instance._info['replica_of']['id'],
|
||||
'Unexpected replication master ID')
|
||||
@ -138,7 +142,8 @@ class ReplicationRunner(TestRunner):
|
||||
self.non_affinity_master_id)
|
||||
|
||||
def run_create_non_affinity_replica(self, expected_http_code=200):
|
||||
self.non_affinity_repl_id = self.auth_client.instances.create(
|
||||
client = self.auth_client
|
||||
self.non_affinity_repl_id = client.instances.create(
|
||||
self.instance_info.name + '_non-affinity-repl',
|
||||
self.instance_info.dbaas_flavor_href,
|
||||
self.instance_info.volume,
|
||||
@ -147,7 +152,7 @@ class ReplicationRunner(TestRunner):
|
||||
nics=self.instance_info.nics,
|
||||
replica_of=self.non_affinity_master_id,
|
||||
replica_count=1).id
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_create_multiple_replicas(self, expected_http_code=200):
|
||||
self.replica_2_id = self.assert_replica_create(
|
||||
@ -176,10 +181,10 @@ class ReplicationRunner(TestRunner):
|
||||
def assert_delete_instances(self, instance_ids, expected_http_code):
|
||||
instance_ids = (instance_ids if utils.is_collection(instance_ids)
|
||||
else [instance_ids])
|
||||
client = self.auth_client
|
||||
for instance_id in instance_ids:
|
||||
self.auth_client.instances.delete(instance_id)
|
||||
self.assert_client_code(expected_http_code,
|
||||
client=self.auth_client)
|
||||
client.instances.delete(instance_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def run_wait_for_delete_non_affinity_repl(
|
||||
self, expected_last_status=['SHUTDOWN']):
|
||||
@ -220,32 +225,36 @@ class ReplicationRunner(TestRunner):
|
||||
|
||||
def run_promote_master(self, expected_exception=exceptions.BadRequest,
|
||||
expected_http_code=400):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.instances.promote_to_replica_source,
|
||||
client, client.instances.promote_to_replica_source,
|
||||
self.instance_info.id)
|
||||
|
||||
def run_eject_replica(self, expected_exception=exceptions.BadRequest,
|
||||
expected_http_code=400):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.instances.eject_replica_source,
|
||||
client, client.instances.eject_replica_source,
|
||||
self.replica_1_id)
|
||||
|
||||
def run_eject_valid_master(self, expected_exception=exceptions.BadRequest,
|
||||
expected_http_code=400):
|
||||
# client = self.auth_client
|
||||
# self.assert_raises(
|
||||
# expected_exception, expected_http_code,
|
||||
# self.auth_client.instances.eject_replica_source,
|
||||
# client, client.instances.eject_replica_source,
|
||||
# self.instance_info.id)
|
||||
# Uncomment once BUG_EJECT_VALID_MASTER is fixed
|
||||
raise SkipKnownBug(runners.BUG_EJECT_VALID_MASTER)
|
||||
|
||||
def run_delete_valid_master(self, expected_exception=exceptions.Forbidden,
|
||||
expected_http_code=403):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.instances.delete,
|
||||
client, client.instances.delete,
|
||||
self.instance_info.id)
|
||||
|
||||
def run_promote_to_replica_source(self,
|
||||
@ -272,9 +281,10 @@ class ReplicationRunner(TestRunner):
|
||||
|
||||
def assert_replica_promote(
|
||||
self, new_master_id, expected_states, expected_http_code):
|
||||
self.auth_client.instances.promote_to_replica_source(new_master_id)
|
||||
self.assert_instance_action(new_master_id, expected_states,
|
||||
expected_http_code)
|
||||
client = self.auth_client
|
||||
client.instances.promote_to_replica_source(new_master_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_instance_action(new_master_id, expected_states)
|
||||
|
||||
def run_verify_replica_data_new_master(self):
|
||||
self.assert_verify_replication_data(
|
||||
@ -340,14 +350,15 @@ class ReplicationRunner(TestRunner):
|
||||
|
||||
def assert_detach_replica(
|
||||
self, replica_id, expected_states, expected_http_code):
|
||||
self.auth_client.instances.edit(replica_id,
|
||||
detach_replica_source=True)
|
||||
self.assert_instance_action(
|
||||
replica_id, expected_states, expected_http_code)
|
||||
client = self.auth_client
|
||||
client.instances.edit(replica_id, detach_replica_source=True)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_instance_action(replica_id, expected_states)
|
||||
|
||||
def _assert_is_not_replica(self, instance_id):
|
||||
instance = self.get_instance(instance_id, client=self.admin_client)
|
||||
self.assert_client_code(200, client=self.admin_client)
|
||||
client = self.admin_client
|
||||
instance = self.get_instance(instance_id, client=client)
|
||||
self.assert_client_code(client, 200)
|
||||
|
||||
if 'replica_of' not in instance._info:
|
||||
try:
|
||||
|
@ -41,8 +41,9 @@ class RootActionsRunner(TestRunner):
|
||||
def _assert_root_state(self, instance_id, expected_state,
|
||||
expected_http_code, message):
|
||||
# The call returns a nameless user object with 'rootEnabled' attribute.
|
||||
response = self.auth_client.root.is_root_enabled(instance_id)
|
||||
self.assert_instance_action(instance_id, None, expected_http_code)
|
||||
client = self.auth_client
|
||||
response = client.root.is_root_enabled(instance_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
actual_state = getattr(response, 'rootEnabled', None)
|
||||
self.assert_equal(expected_state, actual_state, message)
|
||||
|
||||
@ -54,8 +55,9 @@ class RootActionsRunner(TestRunner):
|
||||
|
||||
def assert_root_disable_failure(self, instance_id, expected_exception,
|
||||
expected_http_code):
|
||||
client = self.auth_client
|
||||
self.assert_raises(expected_exception, expected_http_code,
|
||||
self.auth_client.root.delete, instance_id)
|
||||
client, client.root.delete, instance_id)
|
||||
|
||||
def run_enable_root_no_password(self, expected_http_code=200):
|
||||
root_credentials = self.test_helper.get_helper_credentials_root()
|
||||
@ -66,17 +68,18 @@ class RootActionsRunner(TestRunner):
|
||||
|
||||
def assert_root_create(self, instance_id, root_password,
|
||||
expected_root_name, expected_http_code):
|
||||
client = self.auth_client
|
||||
if root_password is not None:
|
||||
root_creds = self.auth_client.root.create_instance_root(
|
||||
root_creds = client.root.create_instance_root(
|
||||
instance_id, root_password)
|
||||
self.assert_equal(root_password, root_creds[1])
|
||||
else:
|
||||
root_creds = self.auth_client.root.create(instance_id)
|
||||
root_creds = client.root.create(instance_id)
|
||||
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
if expected_root_name is not None:
|
||||
self.assert_equal(expected_root_name, root_creds[0])
|
||||
|
||||
self.assert_instance_action(instance_id, None, expected_http_code)
|
||||
self.assert_can_connect(instance_id, root_creds)
|
||||
|
||||
return root_creds
|
||||
@ -122,8 +125,9 @@ class RootActionsRunner(TestRunner):
|
||||
self.assert_root_disable(self.instance_info.id, expected_http_code)
|
||||
|
||||
def assert_root_disable(self, instance_id, expected_http_code):
|
||||
self.auth_client.root.delete(instance_id)
|
||||
self.assert_instance_action(instance_id, None, expected_http_code)
|
||||
client = self.auth_client
|
||||
client.root.delete(instance_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_cannot_connect(self.instance_info.id,
|
||||
self.current_root_creds)
|
||||
|
||||
@ -142,8 +146,9 @@ class RootActionsRunner(TestRunner):
|
||||
def assert_root_delete_failure(self, instance_id, expected_exception,
|
||||
expected_http_code):
|
||||
root_user_name = self.current_root_creds[0]
|
||||
client = self.auth_client
|
||||
self.assert_raises(expected_exception, expected_http_code,
|
||||
self.auth_client.users.delete,
|
||||
client, client.users.delete,
|
||||
instance_id, root_user_name)
|
||||
|
||||
def run_check_root_enabled_after_restore(
|
||||
|
@ -14,6 +14,7 @@
|
||||
# under the License.
|
||||
|
||||
import datetime
|
||||
import inspect
|
||||
import netaddr
|
||||
import os
|
||||
import proboscis
|
||||
@ -321,9 +322,7 @@ class TestRunner(object):
|
||||
|
||||
@property
|
||||
def auth_client(self):
|
||||
if not self._auth_client:
|
||||
self._auth_client = self._create_authorized_client()
|
||||
return self._auth_client
|
||||
return self._create_authorized_client()
|
||||
|
||||
def _create_authorized_client(self):
|
||||
"""Create a client from the normal 'authorized' user."""
|
||||
@ -331,9 +330,7 @@ class TestRunner(object):
|
||||
|
||||
@property
|
||||
def unauth_client(self):
|
||||
if not self._unauth_client:
|
||||
self._unauth_client = self._create_unauthorized_client()
|
||||
return self._unauth_client
|
||||
return self._create_unauthorized_client()
|
||||
|
||||
def _create_unauthorized_client(self):
|
||||
"""Create a client from a different 'unauthorized' user
|
||||
@ -346,9 +343,7 @@ class TestRunner(object):
|
||||
|
||||
@property
|
||||
def admin_client(self):
|
||||
if not self._admin_client:
|
||||
self._admin_client = self._create_admin_client()
|
||||
return self._admin_client
|
||||
return self._create_admin_client()
|
||||
|
||||
def _create_admin_client(self):
|
||||
"""Create a client from an admin user."""
|
||||
@ -358,9 +353,7 @@ class TestRunner(object):
|
||||
|
||||
@property
|
||||
def swift_client(self):
|
||||
if not self._swift_client:
|
||||
self._swift_client = self._create_swift_client()
|
||||
return self._swift_client
|
||||
return self._create_swift_client()
|
||||
|
||||
def _create_swift_client(self):
|
||||
"""Create a swift client from the admin user details."""
|
||||
@ -377,9 +370,7 @@ class TestRunner(object):
|
||||
|
||||
@property
|
||||
def nova_client(self):
|
||||
if not self._nova_client:
|
||||
self._nova_client = create_nova_client(self.instance_info.user)
|
||||
return self._nova_client
|
||||
return create_nova_client(self.instance_info.user)
|
||||
|
||||
def get_client_tenant(self, client):
|
||||
tenant_name = client.real_client.client.tenant
|
||||
@ -389,11 +380,26 @@ class TestRunner(object):
|
||||
return tenant_name, tenant_id
|
||||
|
||||
def assert_raises(self, expected_exception, expected_http_code,
|
||||
client_cmd, *cmd_args, **cmd_kwargs):
|
||||
client, client_cmd, *cmd_args, **cmd_kwargs):
|
||||
if client:
|
||||
# Make sure that the client_cmd comes from the same client that
|
||||
# was passed in, otherwise asserting the client code may fail.
|
||||
cmd_clz = client_cmd.im_self
|
||||
cmd_clz_name = cmd_clz.__class__.__name__
|
||||
client_attrs = [attr[0] for attr in inspect.getmembers(
|
||||
client.real_client)
|
||||
if '__' not in attr[0]]
|
||||
match = [getattr(client, a) for a in client_attrs
|
||||
if getattr(client, a).__class__.__name__ == cmd_clz_name]
|
||||
self.assert_true(any(match),
|
||||
"Could not find method class in client: %s" %
|
||||
client_attrs)
|
||||
self.assert_equal(
|
||||
match[0], cmd_clz,
|
||||
"Test error: client_cmd must be from client obj")
|
||||
asserts.assert_raises(expected_exception, client_cmd,
|
||||
*cmd_args, **cmd_kwargs)
|
||||
|
||||
self.assert_client_code(expected_http_code)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
def get_datastore_config_property(self, name, datastore=None):
|
||||
"""Get a Trove configuration property for a given datastore.
|
||||
@ -429,17 +435,14 @@ class TestRunner(object):
|
||||
def has_do_not_delete_instance(self):
|
||||
return self.has_env_flag(self.DO_NOT_DELETE_INSTANCE_FLAG)
|
||||
|
||||
def assert_instance_action(
|
||||
self, instance_ids, expected_states, expected_http_code=None):
|
||||
self.assert_client_code(expected_http_code)
|
||||
def assert_instance_action(self, instance_ids, expected_states):
|
||||
if expected_states:
|
||||
self.assert_all_instance_states(
|
||||
instance_ids if utils.is_collection(instance_ids)
|
||||
else [instance_ids], expected_states)
|
||||
|
||||
def assert_client_code(self, expected_http_code, client=None):
|
||||
if expected_http_code is not None:
|
||||
client = client or self.auth_client
|
||||
def assert_client_code(self, client, expected_http_code):
|
||||
if client and expected_http_code is not None:
|
||||
self.assert_equal(expected_http_code, client.last_http_code,
|
||||
"Unexpected client status code")
|
||||
|
||||
@ -691,19 +694,20 @@ class TestRunner(object):
|
||||
not be changed by individual test-cases.
|
||||
"""
|
||||
database_def, user_def, root_def = self.build_helper_defs()
|
||||
client = self.auth_client
|
||||
if database_def:
|
||||
self.report.log(
|
||||
"Creating a helper database '%s' on instance: %s"
|
||||
% (database_def['name'], instance_id))
|
||||
self.auth_client.databases.create(instance_id, [database_def])
|
||||
self.wait_for_database_create(instance_id, [database_def])
|
||||
client.databases.create(instance_id, [database_def])
|
||||
self.wait_for_database_create(client, instance_id, [database_def])
|
||||
|
||||
if user_def:
|
||||
self.report.log(
|
||||
"Creating a helper user '%s:%s' on instance: %s"
|
||||
% (user_def['name'], user_def['password'], instance_id))
|
||||
self.auth_client.users.create(instance_id, [user_def])
|
||||
self.wait_for_user_create(instance_id, [user_def])
|
||||
client.users.create(instance_id, [user_def])
|
||||
self.wait_for_user_create(client, instance_id, [user_def])
|
||||
|
||||
if root_def:
|
||||
# Not enabling root on a single instance of the cluster here
|
||||
@ -736,14 +740,14 @@ class TestRunner(object):
|
||||
_get_credentials(credentials),
|
||||
_get_credentials(credentials_root))
|
||||
|
||||
def wait_for_user_create(self, instance_id, expected_user_defs):
|
||||
def wait_for_user_create(self, client, instance_id, expected_user_defs):
|
||||
expected_user_names = {user_def['name']
|
||||
for user_def in expected_user_defs}
|
||||
self.report.log("Waiting for all created users to appear in the "
|
||||
"listing: %s" % expected_user_names)
|
||||
|
||||
def _all_exist():
|
||||
all_users = self.get_user_names(instance_id)
|
||||
all_users = self.get_user_names(client, instance_id)
|
||||
return all(usr in all_users for usr in expected_user_names)
|
||||
|
||||
try:
|
||||
@ -753,18 +757,19 @@ class TestRunner(object):
|
||||
self.fail("Some users were not created within the poll "
|
||||
"timeout: %ds" % self.GUEST_CAST_WAIT_TIMEOUT_SEC)
|
||||
|
||||
def get_user_names(self, instance_id):
|
||||
full_list = self.auth_client.users.list(instance_id)
|
||||
def get_user_names(self, client, instance_id):
|
||||
full_list = client.users.list(instance_id)
|
||||
return {user.name: user for user in full_list}
|
||||
|
||||
def wait_for_database_create(self, instance_id, expected_database_defs):
|
||||
def wait_for_database_create(self, client,
|
||||
instance_id, expected_database_defs):
|
||||
expected_db_names = {db_def['name']
|
||||
for db_def in expected_database_defs}
|
||||
self.report.log("Waiting for all created databases to appear in the "
|
||||
"listing: %s" % expected_db_names)
|
||||
|
||||
def _all_exist():
|
||||
all_dbs = self.get_db_names(instance_id)
|
||||
all_dbs = self.get_db_names(client, instance_id)
|
||||
return all(db in all_dbs for db in expected_db_names)
|
||||
|
||||
try:
|
||||
@ -774,8 +779,8 @@ class TestRunner(object):
|
||||
self.fail("Some databases were not created within the poll "
|
||||
"timeout: %ds" % self.GUEST_CAST_WAIT_TIMEOUT_SEC)
|
||||
|
||||
def get_db_names(self, instance_id):
|
||||
full_list = self.auth_client.databases.list(instance_id)
|
||||
def get_db_names(self, client, instance_id):
|
||||
full_list = client.databases.list(instance_id)
|
||||
return {database.name: database for database in full_list}
|
||||
|
||||
|
||||
|
@ -65,9 +65,10 @@ class UserActionsRunner(TestRunner):
|
||||
|
||||
def assert_users_create(self, instance_id, serial_users_def,
|
||||
expected_http_code):
|
||||
self.auth_client.users.create(instance_id, serial_users_def)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
self.wait_for_user_create(instance_id, serial_users_def)
|
||||
client = self.auth_client
|
||||
client.users.create(instance_id, serial_users_def)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.wait_for_user_create(client, instance_id, serial_users_def)
|
||||
return serial_users_def
|
||||
|
||||
def run_user_show(self, expected_http_code=200):
|
||||
@ -80,9 +81,10 @@ class UserActionsRunner(TestRunner):
|
||||
user_name = expected_user_def['name']
|
||||
user_host = expected_user_def.get('host')
|
||||
|
||||
queried_user = self.auth_client.users.get(
|
||||
client = self.auth_client
|
||||
queried_user = client.users.get(
|
||||
instance_id, user_name, user_host)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self._assert_user_matches(queried_user, expected_user_def)
|
||||
|
||||
def _assert_user_matches(self, user, expected_user_def):
|
||||
@ -99,8 +101,9 @@ class UserActionsRunner(TestRunner):
|
||||
|
||||
def assert_users_list(self, instance_id, expected_user_defs,
|
||||
expected_http_code, limit=2):
|
||||
full_list = self.auth_client.users.list(instance_id)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
client = self.auth_client
|
||||
full_list = client.users.list(instance_id)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
listed_users = {user.name: user for user in full_list}
|
||||
self.assert_is_none(full_list.next,
|
||||
"Unexpected pagination in the list.")
|
||||
@ -120,8 +123,8 @@ class UserActionsRunner(TestRunner):
|
||||
"System users should not be included in the 'user-list' output.")
|
||||
|
||||
# Test list pagination.
|
||||
list_page = self.auth_client.users.list(instance_id, limit=limit)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
list_page = client.users.list(instance_id, limit=limit)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
self.assert_true(len(list_page) <= limit)
|
||||
if len(full_list) > limit:
|
||||
@ -137,9 +140,8 @@ class UserActionsRunner(TestRunner):
|
||||
self.assert_equal(expected_marker, marker,
|
||||
"Pagination marker should be the last element "
|
||||
"in the page.")
|
||||
list_page = self.auth_client.users.list(instance_id, marker=marker)
|
||||
self.assert_client_code(expected_http_code,
|
||||
client=self.auth_client)
|
||||
list_page = client.users.list(instance_id, marker=marker)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self.assert_pagination_match(
|
||||
list_page, full_list, limit, len(full_list))
|
||||
|
||||
@ -154,9 +156,10 @@ class UserActionsRunner(TestRunner):
|
||||
def assert_user_access_show(self, instance_id, user_def,
|
||||
expected_http_code):
|
||||
user_name, user_host = self._get_user_name_host_pair(user_def)
|
||||
user_dbs = self.auth_client.users.list_access(instance_id, user_name,
|
||||
hostname=user_host)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
client = self.auth_client
|
||||
user_dbs = client.users.list_access(
|
||||
instance_id, user_name, hostname=user_host)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
expected_dbs = {db_def['name'] for db_def in user_def['databases']}
|
||||
listed_dbs = [db.name for db in user_dbs]
|
||||
@ -189,10 +192,11 @@ class UserActionsRunner(TestRunner):
|
||||
|
||||
def assert_user_access_revoke(self, instance_id, user_name, user_host,
|
||||
database, expected_http_code):
|
||||
self.auth_client.users.revoke(
|
||||
client = self.auth_client
|
||||
client.users.revoke(
|
||||
instance_id, user_name, database, hostname=user_host)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
user_dbs = self.auth_client.users.list_access(
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
user_dbs = client.users.list_access(
|
||||
instance_id, user_name, hostname=user_host)
|
||||
self.assert_false(any(db.name == database for db in user_dbs),
|
||||
"Database should no longer be included in the user "
|
||||
@ -205,10 +209,11 @@ class UserActionsRunner(TestRunner):
|
||||
|
||||
def assert_user_access_grant(self, instance_id, user_name, user_host,
|
||||
database, expected_http_code):
|
||||
self.auth_client.users.grant(
|
||||
client = self.auth_client
|
||||
client.users.grant(
|
||||
instance_id, user_name, [database], hostname=user_host)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
user_dbs = self.auth_client.users.list_access(
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
user_dbs = client.users.list_access(
|
||||
instance_id, user_name, hostname=user_host)
|
||||
self.assert_true(any(db.name == database for db in user_dbs),
|
||||
"Database should be included in the user "
|
||||
@ -278,9 +283,10 @@ class UserActionsRunner(TestRunner):
|
||||
def assert_users_create_failure(
|
||||
self, instance_id, serial_users_def,
|
||||
expected_exception, expected_http_code):
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.users.create, instance_id, serial_users_def)
|
||||
client, client.users.create, instance_id, serial_users_def)
|
||||
|
||||
def run_user_update_with_blank_name(
|
||||
self, expected_exception=exceptions.BadRequest,
|
||||
@ -302,9 +308,10 @@ class UserActionsRunner(TestRunner):
|
||||
expected_exception, expected_http_code):
|
||||
user_name, user_host = self._get_user_name_host_pair(user_def)
|
||||
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.users.update_attributes, instance_id,
|
||||
client, client.users.update_attributes, instance_id,
|
||||
user_name, update_attribites, user_host)
|
||||
|
||||
def _get_user_name_host_pair(self, user_def):
|
||||
@ -338,9 +345,10 @@ class UserActionsRunner(TestRunner):
|
||||
update_attribites, expected_http_code):
|
||||
user_name, user_host = self._get_user_name_host_pair(user_def)
|
||||
|
||||
self.auth_client.users.update_attributes(
|
||||
client = self.auth_client
|
||||
client.users.update_attributes(
|
||||
instance_id, user_name, update_attribites, user_host)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
|
||||
# Update the stored definitions with the new value.
|
||||
expected_def = None
|
||||
@ -350,7 +358,7 @@ class UserActionsRunner(TestRunner):
|
||||
user_def.update(update_attribites)
|
||||
expected_def = user_def
|
||||
|
||||
self.wait_for_user_create(instance_id, self.user_defs)
|
||||
self.wait_for_user_create(client, instance_id, self.user_defs)
|
||||
|
||||
# Verify using 'user-show' and 'user-list'.
|
||||
self.assert_user_show(instance_id, expected_def, 200)
|
||||
@ -388,16 +396,17 @@ class UserActionsRunner(TestRunner):
|
||||
def assert_user_delete(self, instance_id, user_def, expected_http_code):
|
||||
user_name, user_host = self._get_user_name_host_pair(user_def)
|
||||
|
||||
self.auth_client.users.delete(instance_id, user_name, user_host)
|
||||
self.assert_client_code(expected_http_code, client=self.auth_client)
|
||||
self._wait_for_user_delete(instance_id, user_name)
|
||||
client = self.auth_client
|
||||
client.users.delete(instance_id, user_name, user_host)
|
||||
self.assert_client_code(client, expected_http_code)
|
||||
self._wait_for_user_delete(client, instance_id, user_name)
|
||||
|
||||
def _wait_for_user_delete(self, instance_id, deleted_user_name):
|
||||
def _wait_for_user_delete(self, client, instance_id, deleted_user_name):
|
||||
self.report.log("Waiting for deleted user to disappear from the "
|
||||
"listing: %s" % deleted_user_name)
|
||||
|
||||
def _db_is_gone():
|
||||
all_users = self.get_user_names(instance_id)
|
||||
all_users = self.get_user_names(client, instance_id)
|
||||
return deleted_user_name not in all_users
|
||||
|
||||
try:
|
||||
@ -419,9 +428,10 @@ class UserActionsRunner(TestRunner):
|
||||
expected_exception, expected_http_code):
|
||||
user_name, user_host = self._get_user_name_host_pair(user_def)
|
||||
|
||||
client = self.auth_client
|
||||
self.assert_raises(
|
||||
expected_exception, expected_http_code,
|
||||
self.auth_client.users.get, instance_id, user_name, user_host)
|
||||
client, client.users.get, instance_id, user_name, user_host)
|
||||
|
||||
def run_system_user_show(
|
||||
self, expected_exception=exceptions.BadRequest,
|
||||
@ -456,8 +466,9 @@ class UserActionsRunner(TestRunner):
|
||||
expected_exception, expected_http_code):
|
||||
user_name, user_host = self._get_user_name_host_pair(user_def)
|
||||
|
||||
client = self.auth_client
|
||||
self.assert_raises(expected_exception, expected_http_code,
|
||||
self.auth_client.users.delete,
|
||||
client, client.users.delete,
|
||||
instance_id, user_name, user_host)
|
||||
|
||||
def run_system_user_delete(
|
||||
|
Loading…
x
Reference in New Issue
Block a user