def test_resize_to_xxlarge_instance(self): """ Resize the instance to xxlarge """ dbaas = self.dbaas_provider.client.reddwarfclient if testutil.isInstanceActive(dbaas, instanceId=self.instance_id): dbaas.instances.resize_instance(self.instance_id, self.flavorTypes.xxlarge) httpCode = testutil.get_last_response_code(dbaas) self.assertTrue(httpCode == '202', "Create instance failed with code %s" % httpCode) testutil.waitForActive(dbaas, instanceId=self.instance_id) self.assertTrue(testutil.getInstanceStatus(dbaas, instanceId=self.instance_id) == 'ACTIVE', "Instance is not in Active statue") newFlavorSize = dbaas.instances.get(self.instance_id).flavor['id'] self.assertTrue(newFlavorSize == str(self.flavorTypes.xxlarge), "Unexpected flavor size for resize: %s" % newFlavorSize) #Resize back to tiny if testutil.isInstanceActive(dbaas, instanceId=self.instance_id): dbaas.instances.resize_instance(self.instance_id, self.flavorTypes.tiny) httpCode = testutil.get_last_response_code(dbaas) self.assertTrue(httpCode == '202', "Create instance failed with code %s" % httpCode) testutil.waitForActive(dbaas, instanceId=self.instance_id) self.assertTrue(testutil.getInstanceStatus(dbaas, instanceId=self.instance_id) == 'ACTIVE', "Instance is not in Active statue")
def test_usage_08_duplicate_create(self): """ Delete one instance then recreate it, ensure separate AH events """ tc_name = "Usage 08 tests" tc_num = 8 instance_id = self.instance_id_list[0] inst_name = self.client.instances.get(instance_id).name # delete the existing instance if testutil.getInstanceStatus(self.client, instance_id) == "ACTIVE": self.client.instances.get(instance_id).delete() self.instance_id_list.remove(instance_id) duration = datetime.utcnow() - self.starttime_list[tc_num] rootAction = "reddwarf.instance.delete" # AH Event Sent - Check AH data data AFTER the DELETE time.sleep(self.AHDELAY) AHEventsList = self.dbaas_atomhopper_provider.events_by_resourceId(instance_id) single_event = [event for event in AHEventsList if event.rootAction == rootAction].pop() self.assertEqual( single_event.resourceId, instance_id, "AH resourceID:%r != created instanceID:%r" % (single_event.resourceId, instance_id), ) testutil.valid_duration(duration, single_event, self.dateFormat) # now create an exact duplicate instance startTime1 = datetime.utcnow() instance_id1, elapsed_time = testutil.create_active_instance( self.client, name=inst_name, flavor_id=2, volume={"size": 2}, databases=[{"name": "db_name"}] ) httpCode = testutil.get_last_response_code(self.client) if httpCode != "200": raise Exception("Create instance failed with code %s" % httpCode) self.fixture_log.debug( "Inst: %r is: %r after: %r seconds" % (instance_id, self.client.instances.get(instance_id).status, elapsed_time) ) running_time = (datetime.utcnow() - self.starttime_list[tc_num]).seconds if 5 * self.ONEMIN > running_time: time.sleep((5 * self.ONEMIN) - running_time) # delete the ACTIVE instance if testutil.getInstanceStatus(self.client, instance_id1) == "ACTIVE": self.client.instances.get(instance_id1).delete() duration = datetime.utcnow() - self.starttime_list[tc_num] rootAction = "reddwarf.instance.delete" # AH Event Sent - Check AH data data AFTER the DELETE time.sleep(self.AHDELAY) AHEventsList = self.dbaas_atomhopper_provider.events_by_resourceId(instance_id1) single_event = [event for event in AHEventsList if event.rootAction == rootAction].pop() self.assertEqual( single_event.resourceId, instance_id1, "AH resourceID:%r != created instanceID:%r" % (single_event.resourceId, instance_id1), ) testutil.valid_duration(duration, single_event, self.dateFormat)
def tearDownClass(cls): """ Tearing down: Deleting the instance if in active state """ #Delete the instance ID created for test if active status = testutil.getInstanceStatus(cls.dbaas_creator, cls.creator_instance_id) if testutil.isInstanceActive(cls.dbaas_creator, instanceStatus=status): cls.dbaas_admin.instances.get(cls.creator_instance_id).delete() status = testutil.getInstanceStatus(cls.dbaas_admin, cls.admin_instance_id) if testutil.isInstanceActive(cls.dbaas_admin, instanceStatus=status): cls.dbaas_admin.instances.get(cls.admin_instance_id).delete()
def test_create_required_params_instance(self): """ Creating an instance for smoke testing """ dbaas = self.dbaas_provider.client.reddwarfclient NAME = "qe-req-params-instance" FLAVOR = 1 VOLUME = 10 instance = dbaas.instances.create( name=NAME, flavor_id=FLAVOR, volume={"size": VOLUME}) httpCode = testutil.get_last_response_code(dbaas) self.req_params_instance_id = instance.id self.assertTrue(httpCode == '200', "Create instance failed with code %s" % httpCode) testutil.waitForActive(dbaas, instanceId=instance.id) self.assertTrue(testutil.getInstanceStatus(dbaas, instanceId=instance.id) == 'ACTIVE', "Instance is not in Active statue") #Get the instance and check instance attribs: such as the flavor / volume size instance = self.dbaas.instances.get(instance) self.assertTrue(instance.flavor['id'] == str(FLAVOR)) self.assertTrue(instance.volume['size'] == VOLUME) self.assertTrue(instance.name == NAME) #try to find our instance in the list self.assertTrue(testutil.found_resource(self.dbaas, instanceId=instance.id), "Did not find our instance id: %s in the list." % instance.id)
def test_resize_volume(self): """ Test Resize volume """ tc_name = "Resize Volume" resize_vol = 6 try: self.dbaas.instances.resize_volume(self.instance_id, resize_vol) status = testutil.getInstanceStatus(self.dbaas, self.instance_id) # check interim status of RESIZE self.assertEqual(status, "RESIZE", "Error: instance is not RESIZE, it is: %s" % status) testutil.waitForActive(self.dbaas, instanceId=self.instance_id) #Get the new volume size volume_size = self.dbaas.instances.get(self.instance_id).volume["size"] self.assertEqual(resize_vol, volume_size, "Error: Flavors do not match: %s != %s" % (resize_vol, volume_size)) if self.stability_mode: testutil.write_to_report(tc_name, tc_pass=True) except Exception as e: if self.stability_mode: testutil.write_to_error_report(self.instance_id, repr(e)) testutil.write_to_report(tc_name, tc_pass=False) raise
def test_create_user_req_params(self): _user = [] _user_name = "F343jasdf" _user.append({"name": _user_name, "password": "******"}) self.dbaas.users.create(self.instance_id, _user) httpCode = testutil.get_last_response_code(self.dbaas) self.assertTrue(httpCode == '202', "Create instance failed with code %s" % httpCode) testutil.waitForActive(self.dbaas, instanceId=self.instance_id) #print (self.instance_id) self.assertTrue(testutil.getInstanceStatus(self.dbaas, instanceId=self.instance_id) == 'ACTIVE', "Instance is not in Active statue") #Get the instance and check instance attribs: such as the flavor / volume size #TODO: need to verify this list later... _users = self.dbaas.users.list(self.dbaas.instances.get(self.instance_id)) #self.assertTrue(len(_users) == 1, "Expected 1 user: Got: %s " % len(_users)) #try to find our instance in the list self.assertTrue(testutil.found_resource(self.dbaas, instanceId=self.instance_id, userName=_user_name), "Did not find our user name: %s in the list." % _user_name) self.dbaas.users.delete(self.instance_id, _user_name) self.assertFalse(testutil.found_resource(self.dbaas, instanceId=self.instance_id, userName=_user_name), "Delete error: Found user name: %s in the list." % _user_name)
def test_create_db_singular(self): db_name = "1234FiRstdb" _databases = [{"name": db_name, "character_set": "latin2", "collate": "latin2_general_ci"}] self.dbaas.databases.create(self.instance_id, _databases) httpCode = testutil.get_last_response_code(self.dbaas) self.assertTrue(httpCode == '202', "Create instance failed with code %s" % httpCode) testutil.waitForActive(self.dbaas, instanceId=self.instance_id) #print (self.instance_id) self.assertTrue(testutil.getInstanceStatus(self.dbaas, instanceId=self.instance_id) == 'ACTIVE', "Instance is not in Active statue") #Get the instance and check instance attribs: such as the flavor / volume size _databases = self.dbaas.databases.list(self.dbaas.instances.get(self.instance_id)) self.assertTrue(len(_databases) == 1, "Expected 1 database: Got: %s " % len(_databases)) #try to find our instance in the list self.assertTrue(testutil.found_resource(self.dbaas, instanceId=self.instance_id, databaseName=db_name), "Did not find our database name: %s in the list." % db_name) self.dbaas.databases.delete(self.instance_id, db_name) self.assertFalse(testutil.found_resource(self.dbaas, instanceId=self.instance_id, databaseName=db_name), "Delete error: Found database name: %s in the list." % db_name)
def test_usage_01_delete_after_create(self): """ Delete one instance after 10 minutes """ tc_name = "Usage 01 tests" tc_num = 01 instance_id = self.instance_id_list[0] # Sleep for 10 minutes running_time = (datetime.utcnow() - self.starttime_list[tc_num]).seconds if 10 * self.ONEMIN > running_time: time.sleep((10 * self.ONEMIN) - running_time) # delete the ACTIVE instance if testutil.getInstanceStatus(self.client, instance_id) == "ACTIVE": self.client.instances.get(instance_id).delete() self.instance_id_list.remove(instance_id) duration = datetime.utcnow() - self.starttime_list[tc_num] rootAction = "reddwarf.instance.delete" # AH Event Sent - Check AH data data AFTER the DELETE time.sleep(self.AHDELAY) AHEventsList = self.dbaas_atomhopper_provider.events_by_resourceId(instance_id) single_event = [event for event in AHEventsList if event.rootAction == rootAction].pop() self.assertEqual( single_event.resourceId, instance_id, "AH resourceID:%r != created instanceID:%r" % (single_event.resourceId, instance_id), ) testutil.valid_duration(duration, single_event, self.dateFormat)
def setUp(self): """ Run this setup for each test to ensure an active instance is available """ super(SmokeTest, self).setUp() tc_name = "Create Instance" instance_status = testutil.getInstanceStatus(self.dbaas, instanceId=self.instance_id) if (testutil.isInstanceActive(self.dbaas, instanceStatus=instance_status) is False): #start a new instance and set the global instance ID NAME = "qe-smoke" FLAVOR = 4 VOLUME = 1 try: instance = self.dbaas.instances.create( name=NAME, flavor_id=FLAVOR, volume={"size": VOLUME}, databases=[{"databases": [{"name": "databaseA"}], "name": "dbuser1", "password": "******"}]) httpCode = testutil.get_last_response_code(self.dbaas) if httpCode != '200': raise Exception("Create instance failed with code %s" % httpCode) self.instance_id = instance.id testutil.waitForActive(self.dbaas, instanceId=self.instance_id) if self.stability_mode: testutil.write_to_report(tc_name, tc_pass=True) except Exception as e: if self.stability_mode: testutil.write_to_error_report(self.instance_id, repr(e)) testutil.write_to_report(tc_name, tc_pass=False) raise
def test_create_tiny_instance(self): """ Creating an instance for smoke testing """ #database = self.dbaas_provider.client.reddwarfclient NAME = "qe-tiny-instance" FLAVOR = 1 VOLUME = 20 instance = self.dbaas.instances.create( name=NAME, flavor_id=FLAVOR, volume={"size": VOLUME}, databases=[{"databases": [{"name": "databaseA"}], "name": "dbuser1", "password": "******"}]) httpCode = testutil.get_last_response_code(self.dbaas) self.assertTrue(httpCode == '200', "Create instance failed with code %s" % httpCode) testutil.waitForActive(self.dbaas, instanceId=instance.id) self.tiny_instance_id = instance.id #print (self.instance_id) self.assertTrue(testutil.getInstanceStatus(self.dbaas, instanceId=instance.id) == 'ACTIVE', "Instance is not in Active statue") #Get the instance and check instance attribs: such as the flavor / volume size instance = self.dbaas.instances.get(instance) self.assertTrue(instance.flavor['id'] == str(FLAVOR)) self.assertTrue(instance.volume['size'] == VOLUME) self.assertTrue(instance.name == NAME) #try to find our instance in the list self.assertTrue(testutil.found_resource(self.dbaas, instanceId=instance.id), "Did not find our instance id: %s in the list." % instance.id)
def test_restart_instance(self): """ test restart of instance """ tc_name = "Restart Instance" try: # restart the instance self.dbaas.instances.restart(self.instance_id) status = testutil.getInstanceStatus(self.dbaas, self.instance_id) # check interim status of REBOOT self.assertEqual(status, "REBOOT", "Error: instance is not REBOOT, it is: %s" % status) testutil.waitForActive(self.dbaas, instanceId=self.instance_id) if self.stability_mode: testutil.write_to_report(tc_name, tc_pass=True) except Exception as e: if self.stability_mode: testutil.write_to_error_report(self.instance_id, repr(e)) testutil.write_to_report(tc_name, tc_pass=False) raise
def setUp(cls): """ Run this setup for each test to ensure an active instance is available """ tc_name = "Create Instance" instance_status = testutil.getInstanceStatus(cls.mgmt_dbaas, instanceId=cls.instance_id) if (testutil.isInstanceActive(cls.mgmt_dbaas, instanceStatus=instance_status) is False): # delete non-Active instance test_actions.mgmt_dbaas.instances.get(cls.instance_id).delete() # start a new instance and set the global instance ID NAME = "qe-mgmt-actions-testing" FLAVOR = 1 VOLUME = 1 try: instance = cls.mgmt_dbaas.instances.create( name=NAME, flavor_id=FLAVOR, volume={"size": VOLUME}, databases=[{"databases": [{"name": "databaseA"}], "name": "dbuser1", "password": "******"}]) httpCode = testutil.get_last_response_code(cls.mgmt_dbaas) if httpCode != '200': raise Exception("Create instance failed with code %s" % (httpCode)) cls.instance_id = instance.id cls.instance = instance testutil.waitForActive(cls.mgmt_dbaas, instanceId=cls.instance_id) except Exception as e: self.fixture_log.debug("\tException: %r" % (e)) raise
def test_usage_00_forever(self): """ Create one instance and never delete it """ tc_name = "Usage 00 tests" tc_num = 00 instance_id = self.instance_id_list[0] print("inst id create: [%r] - %r" % (tc_num, self.instance_id_list[tc_num])) if testutil.getInstanceStatus(self.client, instance_id) == "ACTIVE": self.instance_id_list.remove(instance_id)
def test_usage_02_resize_flavor_up(self): """ Dynamically increase the memory size of an instance """ tc_name = "Usage 02 tests" tc_num = 02 NEW_FLAVOR_UP = 4 instance_id = self.instance_id_list[0] # insure instance was ACTIVE for 10 minutes running_time = (datetime.utcnow() - self.starttime_list[tc_num]).seconds if 10 * self.ONEMIN > running_time: time.sleep((10 * self.ONEMIN) - running_time) # resize the instance UP rootAction = "reddwarf.instance.modify_flavor" response = self.client.instances.resize_instance(instance_id, NEW_FLAVOR_UP) self.assertEqual( str(testutil.get_last_response_code(self.client)), "202", "Error: Resize instance. Unexpected resp code: %r != %r" % (str(testutil.get_last_response_code(self.client)), "202"), ) # wait for it to return to Active testutil.wait_for_status(self.client, instance_id, "RESIZE") status, elapsed_time = testutil.waitForActive(self.client, instanceId=instance_id) self.fixture_log.debug("Inst: %r is: %r after: %r seconds" % (instance_id, status, elapsed_time)) duration = datetime.utcnow() - self.starttime_list[tc_num] startTime = datetime.utcnow() # AH Event Sent - Check instance as a result of RESIZE time.sleep(self.AHDELAY) AHEventsList = self.dbaas_atomhopper_provider.events_by_resourceId(instance_id) single_event = [event for event in AHEventsList if event.rootAction == rootAction].pop() self.assertEqual( single_event.resourceId, instance_id, "AH resourceID:%r != created instanceID:%r" % (single_event.resourceId, instance_id), ) testutil.valid_duration(duration, single_event, self.dateFormat) self.instance = self.client.instances.get(instance_id) self.assertEqual( str(NEW_FLAVOR_UP), self.instance.flavor["id"], "Error: Expected flavor of: %r != Actual flavor: %r" % (str(NEW_FLAVOR_UP), self.instance.flavor["id"]), ) time.sleep(5 * self.ONEMIN) # Capture the duration and delete the instance if testutil.getInstanceStatus(self.client, instance_id) == "ACTIVE": self.client.instances.get(instance_id).delete() self.instance_id_list.remove(instance_id) duration = datetime.utcnow() - startTime rootAction = "reddwarf.instance.delete" # AH Event Sent - Check instance data AFTER the DELETE time.sleep(self.AHDELAY) AHEventsList = self.dbaas_atomhopper_provider.events_by_resourceId(instance_id) single_event = [event for event in AHEventsList if event.rootAction == rootAction].pop() self.assertEqual( single_event.resourceId, instance_id, "AH resourceID:%r != created instanceID:%r" % (single_event.resourceId, instance_id), ) testutil.valid_duration(duration, single_event, self.dateFormat)
def test_resize_volume_instance(self): """ Resize the volume of an instance """ dbaas = self.dbaas_provider.client.reddwarfclient if testutil.isInstanceActive(dbaas, instanceId=self.instance_id): dbaas.instances.resize_volume(self.instance_id, self.ResizeUpSizes.lev1) httpCode = testutil.get_last_response_code(dbaas) self.assertTrue(httpCode == '202', "Create instance failed with code %s" % httpCode) testutil.waitForActive(dbaas, instanceId=self.instance_id) self.assertTrue(testutil.getInstanceStatus(dbaas, instanceId=self.instance_id) == 'ACTIVE', "Instance is not in Active statue") newVolume = dbaas.instances.get(self.instance_id).volume['size'] self.assertTrue(newVolume == self.ResizeUpSizes.lev1, "Expected new volume size %s: Got %s " % (self.ResizeUpSizes.lev1, newVolume)) if testutil.isInstanceActive(dbaas, instanceId=self.instance_id): dbaas.instances.resize_volume(self.instance_id, self.ResizeUpSizes.lev2) httpCode = testutil.get_last_response_code(dbaas) self.assertTrue(httpCode == '202', "Create instance failed with code %s" % httpCode) testutil.waitForActive(dbaas, instanceId=self.instance_id) self.assertTrue(testutil.getInstanceStatus(dbaas, instanceId=self.instance_id) == 'ACTIVE', "Instance is not in Active statue") newVolume = dbaas.instances.get(self.instance_id).volume['size'] self.assertTrue(newVolume == self.ResizeUpSizes.lev2, "Expected new volume size %s: Got %s " % (self.ResizeUpSizes.lev2, newVolume)) if testutil.isInstanceActive(dbaas, instanceId=self.instance_id): dbaas.instances.resize_volume(self.instance_id, self.ResizeUpSizes.lev3) httpCode = testutil.get_last_response_code(dbaas) self.assertTrue(httpCode == '202', "Create instance failed with code %s" % httpCode) testutil.waitForActive(dbaas, instanceId=self.instance_id) self.assertTrue(testutil.getInstanceStatus(dbaas, instanceId=self.instance_id) == 'ACTIVE', "Instance is not in Active statue") newVolume = dbaas.instances.get(self.instance_id).volume['size'] self.assertTrue(newVolume == self.ResizeUpSizes.lev3, "Expected new volume size %s: Got %s " % (self.ResizeUpSizes.lev3, newVolume))
def tearDownClass(cls): """ Tearing down: Deleting the instance if in active state """ status = None # Delete the instances created for test if active for inst_id in cls.instance_id_list: status = testutil.getInstanceStatus(cls.client, inst_id) if testutil.isInstanceActive(cls.client, instanceStatus=status): # print("tearDownClass - Deleting: %r" % # cls.client.instances.get(inst_id).id) cls.client.instances.get(inst_id).delete()
def tearDownClass(cls): """ Tearing down: Deleting the instance if in active state """ #Delete the instance ID created for test if active if cls.instance_id is not None: status = testutil.getInstanceStatus(cls.dbaas, instanceId=cls.instance_id) if testutil.isInstanceActive(cls.dbaas, instanceStatus=status): cls.dbaas.instances.get(cls.instance_id).delete()
def test_resize_instance(self): """ test resize of instance """ tc_name = "Resize Instance" next_flavor = 1 final_flavor = 2 try: self.dbaas.instances.resize_instance(self.instance_id, next_flavor) status = testutil.getInstanceStatus(self.dbaas, self.instance_id) self.assertEqual(status, "RESIZE", "Error: instance is not RESIZE, it is: %s" % status) testutil.waitForActive(self.dbaas, instanceId=self.instance_id) #get the new flavorId flavorId = self.dbaas.instances.get(self.instance_id).flavor["id"] self.assertEqual(str(next_flavor), flavorId, "Error: Flavors do not match: %s != %s" % (next_flavor, flavorId)) self.dbaas.instances.resize_instance(self.instance_id, final_flavor) status = testutil.getInstanceStatus(self.dbaas, self.instance_id) self.assertEqual(status, "RESIZE", "Error: instance is not RESIZE, it is: %s" % status) testutil.waitForActive(self.dbaas, instanceId=self.instance_id) #get the new flavorId flavorId = self.dbaas.instances.get(self.instance_id).flavor["id"] self.assertEqual(str(final_flavor), flavorId, "Error: Flavors do not match: %s != %s" % (final_flavor, flavorId)) if self.stability_mode: testutil.write_to_report(tc_name, tc_pass=True) except Exception as e: if self.stability_mode: testutil.write_to_error_report(self.instance_id, repr(e)) testutil.write_to_report(tc_name, tc_pass=False) raise
def tearDownClass(cls): """ Tearing down: Deleting the instance if in active state """ instance_id = test_resize_volume_instances.instance_id dbaas = test_resize_volume_instances.dbaas #Delete the instance ID created for test if active if instance_id is not None: status = testutil.getInstanceStatus(dbaas, instanceId=instance_id) if testutil.isInstanceActive(dbaas, instanceStatus=status): dbaas.instances.get(instance_id).delete()
def test_create_multi_user_with_multi_db(self): _db_name1 = "multi_user_with_multi-database" _db_name2 = "multi_user_with_multi-db2" _databases = [{"name": _db_name1}, {"name": _db_name2}] _test_users = [] _test_users.append({"name": "F343jasdf_", "password": "******", "databases": _databases}) _test_users.append({"name": "403F23F343jasdf", "password": "******", "databases": _databases}) _test_users.append({"name": "easy_user_name", "password": "******", "databases": _databases}) self.dbaas.users.create(self.instance_id, _test_users) httpCode = testutil.get_last_response_code(self.dbaas) self.assertTrue(httpCode == '202', "Create instance failed with code %s" % httpCode) testutil.waitForActive(self.dbaas, instanceId=self.instance_id) #print (self.instance_id) self.assertTrue(testutil.getInstanceStatus(self.dbaas, instanceId=self.instance_id) == 'ACTIVE', "Instance is not in Active statue") #Get the instance and check user dbs _user_list = self.dbaas.users.list(self.dbaas.instances.get(self.instance_id)) #self.assertTrue(len(_user_list) == len(_test_users), "Expected %s user: Got: %s " # % (len(_test_users), len(_user_list))) for _user in _user_list: self.assertEqual(_user.databases, _databases) #try to find our user in the list self.assertTrue(testutil.found_resource(self.dbaas, instanceId=self.instance_id, userName=_user.name), "Did not find our user name: %s in the list." % _user.name) self.dbaas.users.delete(self.instance_id, _user.name) self.assertFalse(testutil.found_resource(self.dbaas, instanceId=self.instance_id, userName=_user.name), "Delete error: Found user name: %s in the list." % _user.name)
def test_performance(self): #Create the Instance to use self.fh.write("Creating the perf instance\n") instance_id = testutil.create_perf_instance(self.client) instance_hostname = testutil.getInstanceHostname(self.client, instance_id) self.fh.write("Connecting to the perf server %s\n" % self.config.dbaas.perf_server) conn = self.connection(host=self.config.dbaas.perf_server, uname=self.config.dbaas.perf_server_user, pw=self.config.dbaas.perf_server_password) time.sleep(5) iuser_name = "perfUser" iuser_password = "******" idb_name = "perfDB" #Commands prep = 'sysbench --test=oltp --oltp-table-size=2000000 --mysql-user='******' --mysql-password='******' --mysql-host=' \ + instance_hostname + ' --mysql-database=' \ + idb_name + ' --mysql-table-engine=innodb prepare' runtest = 'sysbench --max-time=3600 --num-threads=124 --max-requests=2000000 --test=oltp --mysql-user='******' --mysql-password='******' --mysql-host=' + \ instance_hostname + ' --mysql-database=' + \ idb_name + ' run' cleanup = 'sysbench --test=oltp --mysql-user='******' --mysql-host=' + \ instance_hostname + ' --mysql-password='******' --mysql-database=' + \ idb_name + ' cleanup' self.run_command(conn, prep) self.run_command(conn, runtest) self.run_command(conn, cleanup) conn.close() #Delete the instance self.fh.write("Deleting the perf instance\n") status = testutil.getInstanceStatus(self.client, instance_id) if testutil.isInstanceActive(self.client, instanceStatus=status): self.client.instances.get(instance_id).delete() self.fh.close()
def test_create_2_users_instance(self): """ Creating an instance for smoke testing """ dbaas = self.dbaas_provider.client.reddwarfclient NAME = "qe-2users-instance" FLAVOR = 1 VOLUME = 10 databases = [] databases.append({"name": "firstdb", "character_set": "latin2", "collate": "latin2_general_ci"}) users = [] users.append({"name": "lite", "password": "******", "databases": [{"name": "firstdb"}]}) users.append({"name": "lite1", "password": "******", "databases": [{"name": "firstdb"}]}) instance = dbaas.instances.create( name=NAME, flavor_id=FLAVOR, volume={"size": VOLUME}, databases=databases, users=users) httpCode = testutil.get_last_response_code(dbaas) self.multi_users_instance_id = instance.id self.assertTrue(httpCode == '200', "Create instance failed with code %s" % httpCode) testutil.waitForActive(dbaas, instanceId=instance.id) self.assertTrue(testutil.getInstanceStatus(dbaas, instanceId=instance.id) == 'ACTIVE', "Instance is not in Active statue") #Get the instance and check instance attribs: such as the flavor / volume size instance = self.dbaas.instances.get(instance) self.assertTrue(instance.flavor['id'] == str(FLAVOR)) self.assertTrue(instance.volume['size'] == VOLUME) self.assertTrue(instance.name == NAME) #try to find our instance in the list self.assertTrue(testutil.found_resource(self.dbaas, instanceId=instance.id), "Did not find our instance id: %s in the list." % instance.id)
def test_usage_05_restart_mysql(self): """ Restart MySQL then Delete one instance after 10 minutes """ tc_name = "Usage 05 tests" tc_num = 05 instance_id = self.instance_id_list[0] self.client.instances.restart(instance_id) self.assertEqual( str(testutil.get_last_response_code(self.client)), "202", "Error: Resize instance. Unexpected resp code: %r != %r" % (str(testutil.get_last_response_code(self.client)), "202"), ) # check interim status of REBOOT testutil.wait_for_status(self.client, instance_id, "REBOOT") # wait for active, ensure time elapsed, record the duration status, elapsed_time = testutil.waitForActive(self.client, instanceId=instance_id) self.fixture_log.debug("Inst: %r is: %r after: %r seconds" % (instance_id, status, elapsed_time)) running_time = (datetime.utcnow() - self.starttime_list[tc_num]).seconds if 10 * self.ONEMIN > running_time: time.sleep((10 * self.ONEMIN) - running_time) # delete the ACTIVE instance if testutil.getInstanceStatus(self.client, instance_id) == "ACTIVE": self.client.instances.get(instance_id).delete() self.instance_id_list.remove(instance_id) duration = datetime.utcnow() - self.starttime_list[tc_num] rootAction = "reddwarf.instance.delete" # AH Event Sent - Check AH data data AFTER the DELETE time.sleep(self.AHDELAY) AHEventsList = self.dbaas_atomhopper_provider.events_by_resourceId(instance_id) single_event = [event for event in AHEventsList if event.rootAction == rootAction].pop() self.assertEqual( single_event.resourceId, instance_id, "AH resourceID:%r != created instanceID:%r" % (single_event.resourceId, instance_id), ) testutil.valid_duration(duration, single_event, self.dateFormat)
def test_rbac_instance_creator_rights(self): next_flavor = 1 final_flavor = 2 current_instance = None resize_vol = 5 try: # list instances instancesList = self.dbaas_creator.instances.list() self.assertIsNotNone(instancesList) httpCode = testutil.get_last_response_code(self.dbaas_creator) self.assertTrue(httpCode == '200', "DB list: Expected http code: %s | Actual http code: %s " % ('200', httpCode)) # list instance details current_instance = self.dbaas_creator.instances.get(self.creator_instance_id) self.assertIsNotNone(current_instance) httpCode = testutil.get_last_response_code(self.dbaas_creator) self.assertTrue(httpCode == '200', "DB list get ID: Expected http code: %s | Actual http code: %s " % ('200', httpCode)) try: #Enable root self.dbaas_creator.root.create(self.creator_instance_id) except Exception as e: httpCode = testutil.get_last_response_code(self.dbaas_creator) self.assertTrue(httpCode == '405', "Expected http code: %s | Actual http code: %s " % ('405', httpCode)) self.dbaas_creator.root.is_root_enabled(self.creator_instance_id) httpCode = testutil.get_last_response_code(self.dbaas_creator) self.assertTrue(httpCode == '200', "Expected http code: %s | Actual http code: %s " % ('200', httpCode)) # resize instance self.dbaas_creator.instances.resize_instance(self.creator_instance_id, next_flavor) httpCode = testutil.get_last_response_code(self.dbaas_creator) self.assertTrue(httpCode == '202', "DB Resize instance: Expected http code: %s | Actual http code: %s " % ('202', httpCode)) status = testutil.getInstanceStatus(self.dbaas_creator, self.creator_instance_id) self.assertEqual(status, "RESIZE", "Error: instance is not RESIZE, it is: %s" % status) testutil.waitForActive(self.dbaas_creator, instanceId=self.creator_instance_id) #get the new flavorId flavorId = self.dbaas_creator.instances.get(self.creator_instance_id).flavor["id"] self.assertEqual(str(next_flavor), flavorId, "Error: Flavors do not match: %s != %s" % (next_flavor, flavorId)) #resize again self.dbaas_creator.instances.resize_instance(self.creator_instance_id, final_flavor) status = testutil.getInstanceStatus(self.dbaas_creator, self.creator_instance_id) self.assertEqual(status, "RESIZE", "Error: instance is not RESIZE, it is: %s" % status) testutil.waitForActive(self.dbaas_creator, instanceId=self.creator_instance_id) #get the new flavorId flavorId = self.dbaas_creator.instances.get(self.creator_instance_id).flavor["id"] self.assertEqual(str(final_flavor), flavorId, "Error: Flavors do not match: %s != %s" % (final_flavor, flavorId)) #restart instance self.dbaas_creator.instances.restart(self.creator_instance_id) httpCode = testutil.get_last_response_code(self.dbaas_creator) self.assertTrue(httpCode == '202', "DB Restart: Expected http code: %s | Actual http code: %s " % ('202', httpCode)) status = testutil.getInstanceStatus(self.dbaas_creator, self.creator_instance_id) self.assertEqual(status, "REBOOT", "Error: instance is not REBOOT, it is: %s" % status) testutil.waitForActive(self.dbaas_creator, instanceId=self.creator_instance_id) #resize instance volume self.dbaas_creator.instances.resize_volume(self.creator_instance_id, resize_vol) httpCode = testutil.get_last_response_code(self.dbaas_creator) self.assertTrue(httpCode == '202', "DB Resize volume: Expected http code: %s | Actual http code: %s " % ('202', httpCode)) status = testutil.getInstanceStatus(self.dbaas_creator, self.creator_instance_id) self.assertEqual(status, "RESIZE", "Error: instance is not RESIZE, it is: %s" % status) testutil.waitForActive(self.dbaas_creator, instanceId=self.creator_instance_id) #Get the new volume size volume_size = self.dbaas_creator.instances.get(self.creator_instance_id).volume["size"] self.assertEqual(resize_vol, volume_size, "Error: Flavors do not match: %s != %s" % (resize_vol, volume_size)) #Delete an instance try: self.dbaas_creator.instances.get(self.creator_instance_id).delete() except Exception as e: httpCode = testutil.get_last_response_code(self.dbaas_creator) self.assertTrue(httpCode == '405', "DB Instance Delete: Expected http code: %s | Actual http code: %s " % ('405', httpCode)) except Exception as e: self.fail(e)
def test_rbac_instance_admin_rights(self): next_flavor = 1 final_flavor = 2 resize_vol = 5 try: # list instances instancesList = self.dbaas_admin.instances.list() self.assertIsNotNone(instancesList) httpCode = testutil.get_last_response_code(self.dbaas_admin) self.assertTrue(httpCode == '200', "DB List: Expected http code: %s | Actual http code: %s " % ('200', httpCode)) # list instance details current_instance = self.dbaas_admin.instances.get(self.admin_instance_id) self.assertIsNotNone(current_instance) httpCode = testutil.get_last_response_code(self.dbaas_admin) self.assertTrue(httpCode == '200', "DB List Get Id:Expected http code: %s | Actual http code: %s " % ('200', httpCode)) #Enable root user_name, user_password = self.dbaas_admin.root.create(self.admin_instance_id) httpCode = testutil.get_last_response_code(self.dbaas_admin) self.assertTrue(httpCode == '200', "DB Enable Root: Expected http code: %s | Actual http code: %s " % ('200', httpCode)) self.assertEqual(user_name, 'root', "Error: user name is not root") self.assertIsNotNone(user_password, "Error: root password is None") # finally, verify root has been enabled for the instance self.assertTrue(self.dbaas_admin.root.is_root_enabled(self.admin_instance_id), "Error: root is not enabled") # resize instance self.dbaas_admin.instances.resize_instance(self.admin_instance_id, next_flavor) httpCode = testutil.get_last_response_code(self.dbaas_admin) self.assertTrue(httpCode == '202', "DB Resize: Expected http code: %s | Actual http code: %s " % ('202', httpCode)) status = testutil.getInstanceStatus(self.dbaas_admin, self.admin_instance_id) self.assertEqual(status, "RESIZE", "Error: instance is not RESIZE, it is: %s" % status) testutil.waitForActive(self.dbaas_admin, instanceId=self.admin_instance_id) #get the new flavorId flavorId = self.dbaas_admin.instances.get(self.admin_instance_id).flavor["id"] self.assertEqual(str(next_flavor), flavorId, "Error: Flavors do not match: %s != %s" % (next_flavor, flavorId)) #resize again self.dbaas_admin.instances.resize_instance(self.admin_instance_id, final_flavor) status = testutil.getInstanceStatus(self.dbaas_admin, self.admin_instance_id) self.assertEqual(status, "RESIZE", "Error: instance is not RESIZE, it is: %s" % status) testutil.waitForActive(self.dbaas_admin, instanceId=self.admin_instance_id) #get the new flavorId flavorId = self.dbaas_admin.instances.get(self.admin_instance_id).flavor["id"] self.assertEqual(str(final_flavor), flavorId, "Error: Flavors do not match: %s != %s" % (final_flavor, flavorId)) #restart instance self.dbaas_admin.instances.restart(self.admin_instance_id) httpCode = testutil.get_last_response_code(self.dbaas_admin) self.assertTrue(httpCode == '202', "DB Restart: Expected http code: %s | Actual http code: %s " % ('202', httpCode)) status = testutil.getInstanceStatus(self.dbaas_admin, self.admin_instance_id) self.assertEqual(status, "REBOOT", "Error: instance is not REBOOT, it is: %s" % status) testutil.waitForActive(self.dbaas_admin, instanceId=self.admin_instance_id) #resize instance volume self.dbaas_admin.instances.resize_volume(self.admin_instance_id, resize_vol) httpCode = testutil.get_last_response_code(self.dbaas_admin) self.assertTrue(httpCode == '202', "DB Reboot: Expected http code: %s | Actual http code: %s " % ('202', httpCode)) status = testutil.getInstanceStatus(self.dbaas_admin, self.admin_instance_id) self.assertEqual(status, "RESIZE", "Error: instance is not RESIZE, it is: %s" % status) testutil.waitForActive(self.dbaas_admin, instanceId=self.admin_instance_id) #Get the new volume size volume_size = self.dbaas_admin.instances.get(self.admin_instance_id).volume["size"] self.assertEqual(resize_vol, volume_size, "Error: Flavors do not match: %s != %s" % (resize_vol, volume_size)) except Exception as e: self.fail(e)
def test_usage_06_resize_reboot_volume_up(self): """ Resize the Volume Storage and then reboot, ensure only two AH events """ tc_name = "Usage 06 tests" tc_num = 06 NEW_VOLUME = 6 instance_id = self.instance_id_list[0] running_time = (datetime.utcnow() - self.starttime_list[tc_num]).seconds if 10 * self.ONEMIN > running_time: time.sleep((10 * self.ONEMIN) - running_time) # resize the instance UP rootAction = "reddwarf.instance.modify_volume" response = self.client.instances.resize_volume(instance_id, NEW_VOLUME) self.assertEqual( str(testutil.get_last_response_code(self.client)), "202", "Error: Resize instance. Unexpected resp code: %r != %r" % (str(testutil.get_last_response_code(self.client)), "202"), ) testutil.wait_for_status(self.client, instance_id, "RESIZE") status, elapsed_time = testutil.waitForActive(self.client, instanceId=instance_id) self.fixture_log.debug("Inst: %r is: %r after: %r seconds" % (instance_id, status, elapsed_time)) duration = datetime.utcnow() - self.starttime_list[tc_num] startTime = datetime.utcnow() # AH Event Sent - Check instance as a result of RESIZE time.sleep(self.AHDELAY * 2) AHEventsList = self.dbaas_atomhopper_provider.events_by_resourceId(instance_id) single_event = [event for event in AHEventsList if event.rootAction == rootAction].pop() self.assertEqual( single_event.resourceId, instance_id, "AH resourceID:%r != created instanceID:%r" % (single_event.resourceId, instance_id), ) testutil.valid_duration(duration, single_event, self.dateFormat) self.instance = self.client.instances.get(instance_id) # confirm the new flavor self.assertEqual( NEW_VOLUME, self.instance.volume["size"], "Error: Expected flavor of: %r != Actual flavor: %r" % (NEW_VOLUME, self.instance.volume["size"]), ) time.sleep(2 * self.ONEMIN) # restart the instance self.mgmt_client.management.reboot(instance_id) self.assertEqual( str(testutil.get_last_response_code(self.client)), "200", "Error: Resize instance. Unexpected resp code: %r != %r" % (str(testutil.get_last_response_code(self.client)), "200"), ) testutil.wait_for_status(self.client, instance_id, "REBOOT") status, elapsed_time = testutil.waitForActive(self.client, instanceId=instance_id) self.fixture_log.debug("Inst: %r is: %r after: %r seconds" % (instance_id, status, elapsed_time)) time.sleep(2 * self.ONEMIN) # Capture the duration and delete the instance if testutil.getInstanceStatus(self.client, instance_id) == "ACTIVE": self.client.instances.get(instance_id).delete() self.instance_id_list.remove(instance_id) duration = datetime.utcnow() - startTime rootAction = "reddwarf.instance.delete" # AH Event Sent - Check instance data AFTER the DELETE time.sleep(self.AHDELAY) AHEventsList = self.dbaas_atomhopper_provider.events_by_resourceId(instance_id) single_event = [event for event in AHEventsList if event.rootAction == rootAction].pop() self.assertEqual( single_event.resourceId, instance_id, "AH resourceID:%r != created instanceID:%r" % (single_event.resourceId, instance_id), ) testutil.valid_duration(duration, single_event, self.dateFormat)