merge trunk
This commit is contained in:
		| @@ -869,7 +869,7 @@ class InstanceTypeCommands(object): | ||||
|             elif name == "--all": | ||||
|                 inst_types = instance_types.get_all_types(True) | ||||
|             else: | ||||
|                 inst_types = instance_types.get_instance_type(name) | ||||
|                 inst_types = instance_types.get_instance_type_by_name(name) | ||||
|         except exception.DBError, e: | ||||
|             _db_error(e) | ||||
|         if isinstance(inst_types.values()[0], dict): | ||||
| @@ -885,20 +885,17 @@ class ImageCommands(object): | ||||
|     def __init__(self, *args, **kwargs): | ||||
|         self.image_service = utils.import_object(FLAGS.image_service) | ||||
|  | ||||
|     def _register(self, image_type, disk_format, container_format, | ||||
|     def _register(self, container_format, disk_format, | ||||
|                   path, owner, name=None, is_public='T', | ||||
|                   architecture='x86_64', kernel_id=None, ramdisk_id=None): | ||||
|         meta = {'is_public': True, | ||||
|         meta = {'is_public': (is_public == 'T'), | ||||
|                 'name': name, | ||||
|                 'disk_format': disk_format, | ||||
|                 'container_format': container_format, | ||||
|                 'disk_format': disk_format, | ||||
|                 'properties': {'image_state': 'available', | ||||
|                                'owner_id': owner, | ||||
|                                'type': image_type, | ||||
|                                'project_id': owner, | ||||
|                                'architecture': architecture, | ||||
|                                'image_location': 'local', | ||||
|                                'is_public': (is_public == 'T')}} | ||||
|         print image_type, meta | ||||
|                                'image_location': 'local'}} | ||||
|         if kernel_id: | ||||
|             meta['properties']['kernel_id'] = int(kernel_id) | ||||
|         if ramdisk_id: | ||||
| @@ -923,16 +920,18 @@ class ImageCommands(object): | ||||
|         ramdisk_id = self.ramdisk_register(ramdisk, owner, None, | ||||
|                                     is_public, architecture) | ||||
|         self.image_register(image, owner, name, is_public, | ||||
|                        architecture, kernel_id, ramdisk_id) | ||||
|                             architecture, 'ami', 'ami', | ||||
|                             kernel_id, ramdisk_id) | ||||
|  | ||||
|     def image_register(self, path, owner, name=None, is_public='T', | ||||
|                        architecture='x86_64', kernel_id=None, ramdisk_id=None, | ||||
|                        disk_format='ami', container_format='ami'): | ||||
|                        architecture='x86_64', container_format='bare', | ||||
|                        disk_format='raw', kernel_id=None, ramdisk_id=None): | ||||
|         """Uploads an image into the image_service | ||||
|         arguments: path owner [name] [is_public='T'] [architecture='x86_64'] | ||||
|                    [container_format='bare'] [disk_format='raw'] | ||||
|                    [kernel_id=None] [ramdisk_id=None] | ||||
|                    [disk_format='ami'] [container_format='ami']""" | ||||
|         return self._register('machine', disk_format, container_format, path, | ||||
|         """ | ||||
|         return self._register(container_format, disk_format, path, | ||||
|                               owner, name, is_public, architecture, | ||||
|                               kernel_id, ramdisk_id) | ||||
|  | ||||
| @@ -941,7 +940,7 @@ class ImageCommands(object): | ||||
|         """Uploads a kernel into the image_service | ||||
|         arguments: path owner [name] [is_public='T'] [architecture='x86_64'] | ||||
|         """ | ||||
|         return self._register('kernel', 'aki', 'aki', path, owner, name, | ||||
|         return self._register('aki', 'aki', path, owner, name, | ||||
|                               is_public, architecture) | ||||
|  | ||||
|     def ramdisk_register(self, path, owner, name=None, is_public='T', | ||||
| @@ -949,7 +948,7 @@ class ImageCommands(object): | ||||
|         """Uploads a ramdisk into the image_service | ||||
|         arguments: path owner [name] [is_public='T'] [architecture='x86_64'] | ||||
|         """ | ||||
|         return self._register('ramdisk', 'ari', 'ari', path, owner, name, | ||||
|         return self._register('ari', 'ari', path, owner, name, | ||||
|                               is_public, architecture) | ||||
|  | ||||
|     def _lookup(self, old_image_id): | ||||
| @@ -966,16 +965,17 @@ class ImageCommands(object): | ||||
|                    'ramdisk': 'ari'} | ||||
|         container_format = mapping[old['type']] | ||||
|         disk_format = container_format | ||||
|         if container_format == 'ami' and not old.get('kernelId'): | ||||
|             container_format = 'bare' | ||||
|             disk_format = 'raw' | ||||
|         new = {'disk_format': disk_format, | ||||
|                'container_format': container_format, | ||||
|                'is_public': True, | ||||
|                'is_public': old['isPublic'], | ||||
|                'name': old['imageId'], | ||||
|                'properties': {'image_state': old['imageState'], | ||||
|                               'owner_id': old['imageOwnerId'], | ||||
|                               'project_id': old['imageOwnerId'], | ||||
|                               'architecture': old['architecture'], | ||||
|                               'type': old['type'], | ||||
|                               'image_location': old['imageLocation'], | ||||
|                               'is_public': old['isPublic']}} | ||||
|                               'image_location': old['imageLocation']}} | ||||
|         if old.get('kernelId'): | ||||
|             new['properties']['kernel_id'] = self._lookup(old['kernelId']) | ||||
|         if old.get('ramdiskId'): | ||||
|   | ||||
| @@ -84,7 +84,8 @@ class ComputeTestCase(test.TestCase): | ||||
|         inst['launch_time'] = '10' | ||||
|         inst['user_id'] = self.user.id | ||||
|         inst['project_id'] = self.project.id | ||||
|         inst['instance_type'] = 'm1.tiny' | ||||
|         type_id = instance_types.get_instance_type_by_name('m1.tiny')['id'] | ||||
|         inst['instance_type_id'] = type_id | ||||
|         inst['mac_address'] = utils.generate_mac() | ||||
|         inst['ami_launch_index'] = 0 | ||||
|         inst.update(params) | ||||
| @@ -132,7 +133,7 @@ class ComputeTestCase(test.TestCase): | ||||
|         cases = [dict(), dict(display_name=None)] | ||||
|         for instance in cases: | ||||
|             ref = self.compute_api.create(self.context, | ||||
|                 FLAGS.default_instance_type, None, **instance) | ||||
|                 instance_types.get_default_instance_type(), None, **instance) | ||||
|             try: | ||||
|                 self.assertNotEqual(ref[0]['display_name'], None) | ||||
|             finally: | ||||
| @@ -143,7 +144,7 @@ class ComputeTestCase(test.TestCase): | ||||
|         group = self._create_group() | ||||
|         ref = self.compute_api.create( | ||||
|                 self.context, | ||||
|                 instance_type=FLAGS.default_instance_type, | ||||
|                 instance_type=instance_types.get_default_instance_type(), | ||||
|                 image_id=None, | ||||
|                 security_group=['testgroup']) | ||||
|         try: | ||||
| @@ -161,7 +162,7 @@ class ComputeTestCase(test.TestCase): | ||||
|  | ||||
|         ref = self.compute_api.create( | ||||
|                 self.context, | ||||
|                 instance_type=FLAGS.default_instance_type, | ||||
|                 instance_type=instance_types.get_default_instance_type(), | ||||
|                 image_id=None, | ||||
|                 security_group=['testgroup']) | ||||
|         try: | ||||
| @@ -177,7 +178,7 @@ class ComputeTestCase(test.TestCase): | ||||
|  | ||||
|         ref = self.compute_api.create( | ||||
|                 self.context, | ||||
|                 instance_type=FLAGS.default_instance_type, | ||||
|                 instance_type=instance_types.get_default_instance_type(), | ||||
|                 image_id=None, | ||||
|                 security_group=['testgroup']) | ||||
|  | ||||
| @@ -359,8 +360,9 @@ class ComputeTestCase(test.TestCase): | ||||
|         instance_id = self._create_instance() | ||||
|  | ||||
|         self.compute.run_instance(self.context, instance_id) | ||||
|         inst_type = instance_types.get_instance_type_by_name('m1.xlarge') | ||||
|         db.instance_update(self.context, instance_id, | ||||
|                 {'instance_type': 'm1.xlarge'}) | ||||
|                 {'instance_type_id': inst_type['id']}) | ||||
|  | ||||
|         self.assertRaises(exception.ApiError, self.compute_api.resize, | ||||
|                 context, instance_id, 1) | ||||
| @@ -380,8 +382,8 @@ class ComputeTestCase(test.TestCase): | ||||
|         self.compute.terminate_instance(context, instance_id) | ||||
|  | ||||
|     def test_get_by_flavor_id(self): | ||||
|         type = instance_types.get_by_flavor_id(1) | ||||
|         self.assertEqual(type, 'm1.tiny') | ||||
|         type = instance_types.get_instance_type_by_flavor_id(1) | ||||
|         self.assertEqual(type['name'], 'm1.tiny') | ||||
|  | ||||
|     def test_resize_same_source_fails(self): | ||||
|         """Ensure instance fails to migrate when source and destination are | ||||
| @@ -664,4 +666,5 @@ class ComputeTestCase(test.TestCase): | ||||
|  | ||||
|         instances = db.instance_get_all(context.get_admin_context()) | ||||
|         LOG.info(_("After force-killing instances: %s"), instances) | ||||
|         self.assertEqual(len(instances), 0) | ||||
|         self.assertEqual(len(instances), 1) | ||||
|         self.assertEqual(power_state.SHUTOFF, instances[0]['state']) | ||||
|   | ||||
| @@ -62,7 +62,7 @@ class ConsoleTestCase(test.TestCase): | ||||
|         inst['launch_time'] = '10' | ||||
|         inst['user_id'] = self.user.id | ||||
|         inst['project_id'] = self.project.id | ||||
|         inst['instance_type'] = 'm1.tiny' | ||||
|         inst['instance_type_id'] = 1 | ||||
|         inst['mac_address'] = utils.generate_mac() | ||||
|         inst['ami_launch_index'] = 0 | ||||
|         return db.instance_create(self.context, inst)['id'] | ||||
|   | ||||
| @@ -40,7 +40,11 @@ class InstanceTypeTestCase(test.TestCase): | ||||
|         max_flavorid = session.query(models.InstanceTypes).\ | ||||
|                                      order_by("flavorid desc").\ | ||||
|                                      first() | ||||
|         max_id = session.query(models.InstanceTypes).\ | ||||
|                                      order_by("id desc").\ | ||||
|                                      first() | ||||
|         self.flavorid = max_flavorid["flavorid"] + 1 | ||||
|         self.id = max_id["id"] + 1 | ||||
|         self.name = str(int(time.time())) | ||||
|  | ||||
|     def test_instance_type_create_then_delete(self): | ||||
| @@ -53,7 +57,7 @@ class InstanceTypeTestCase(test.TestCase): | ||||
|                             'instance type was not created') | ||||
|         instance_types.destroy(self.name) | ||||
|         self.assertEqual(1, | ||||
|                     instance_types.get_instance_type(self.name)["deleted"]) | ||||
|                     instance_types.get_instance_type(self.id)["deleted"]) | ||||
|         self.assertEqual(starting_inst_list, instance_types.get_all_types()) | ||||
|         instance_types.purge(self.name) | ||||
|         self.assertEqual(len(starting_inst_list), | ||||
|   | ||||
| @@ -263,7 +263,7 @@ class SimpleDriverTestCase(test.TestCase): | ||||
|         inst['reservation_id'] = 'r-fakeres' | ||||
|         inst['user_id'] = self.user.id | ||||
|         inst['project_id'] = self.project.id | ||||
|         inst['instance_type'] = 'm1.tiny' | ||||
|         inst['instance_type_id'] = '1' | ||||
|         inst['mac_address'] = utils.generate_mac() | ||||
|         inst['vcpus'] = kwargs.get('vcpus', 1) | ||||
|         inst['ami_launch_index'] = 0 | ||||
|   | ||||
| @@ -140,7 +140,7 @@ class LibvirtConnTestCase(test.TestCase): | ||||
|                      'vcpus':         2, | ||||
|                      'project_id':    'fake', | ||||
|                      'bridge':        'br101', | ||||
|                      'instance_type': 'm1.small'} | ||||
|                      'instance_type_id': '5'}  # m1.small | ||||
|  | ||||
|     def lazy_load_library_exists(self): | ||||
|         """check if libvirt is available.""" | ||||
| @@ -479,7 +479,7 @@ class LibvirtConnTestCase(test.TestCase): | ||||
|  | ||||
|         fake_timer = FakeTime() | ||||
|  | ||||
|         self.create_fake_libvirt_mock(nwfilterLookupByName=fake_raise) | ||||
|         self.create_fake_libvirt_mock() | ||||
|         instance_ref = db.instance_create(self.context, self.test_instance) | ||||
|  | ||||
|         # Start test | ||||
| @@ -488,6 +488,7 @@ class LibvirtConnTestCase(test.TestCase): | ||||
|             conn = libvirt_conn.LibvirtConnection(False) | ||||
|             conn.firewall_driver.setattr('setup_basic_filtering', fake_none) | ||||
|             conn.firewall_driver.setattr('prepare_instance_filter', fake_none) | ||||
|             conn.firewall_driver.setattr('instance_filter_exists', fake_none) | ||||
|             conn.ensure_filtering_rules_for_instance(instance_ref, | ||||
|                                                      time=fake_timer) | ||||
|         except exception.Error, e: | ||||
|   | ||||
| @@ -106,7 +106,7 @@ class VolumeTestCase(test.TestCase): | ||||
|         inst['launch_time'] = '10' | ||||
|         inst['user_id'] = 'fake' | ||||
|         inst['project_id'] = 'fake' | ||||
|         inst['instance_type'] = 'm1.tiny' | ||||
|         inst['instance_type_id'] = '2'  # m1.tiny | ||||
|         inst['mac_address'] = utils.generate_mac() | ||||
|         inst['ami_launch_index'] = 0 | ||||
|         instance_id = db.instance_create(self.context, inst)['id'] | ||||
|   | ||||
| @@ -80,7 +80,7 @@ class XenAPIVolumeTestCase(test.TestCase): | ||||
|                   'image_id': 1, | ||||
|                   'kernel_id': 2, | ||||
|                   'ramdisk_id': 3, | ||||
|                   'instance_type': 'm1.large', | ||||
|                   'instance_type_id': '3',  # m1.large | ||||
|                   'mac_address': 'aa:bb:cc:dd:ee:ff', | ||||
|                   'os_type': 'linux'} | ||||
|  | ||||
| @@ -328,7 +328,7 @@ class XenAPIVMTestCase(test.TestCase): | ||||
|         self.assertEquals(self.vm['HVM_boot_policy'], '') | ||||
|  | ||||
|     def _test_spawn(self, image_id, kernel_id, ramdisk_id, | ||||
|                     instance_type="m1.large", os_type="linux", | ||||
|                     instance_type_id="3", os_type="linux", | ||||
|                     instance_id=1, check_injection=False): | ||||
|         stubs.stubout_loopingcall_start(self.stubs) | ||||
|         values = {'id': instance_id, | ||||
| @@ -337,7 +337,7 @@ class XenAPIVMTestCase(test.TestCase): | ||||
|                   'image_id': image_id, | ||||
|                   'kernel_id': kernel_id, | ||||
|                   'ramdisk_id': ramdisk_id, | ||||
|                   'instance_type': instance_type, | ||||
|                   'instance_type_id': instance_type_id, | ||||
|                   'mac_address': 'aa:bb:cc:dd:ee:ff', | ||||
|                   'os_type': os_type} | ||||
|         instance = db.instance_create(self.context, values) | ||||
| @@ -349,7 +349,7 @@ class XenAPIVMTestCase(test.TestCase): | ||||
|         FLAGS.xenapi_image_service = 'glance' | ||||
|         self.assertRaises(Exception, | ||||
|                           self._test_spawn, | ||||
|                           1, 2, 3, "m1.xlarge") | ||||
|                           1, 2, 3, "4")  # m1.xlarge | ||||
|  | ||||
|     def test_spawn_raw_objectstore(self): | ||||
|         FLAGS.xenapi_image_service = 'objectstore' | ||||
| @@ -523,7 +523,7 @@ class XenAPIVMTestCase(test.TestCase): | ||||
|             'image_id': 1, | ||||
|             'kernel_id': 2, | ||||
|             'ramdisk_id': 3, | ||||
|             'instance_type': 'm1.large', | ||||
|             'instance_type_id': '3',  # m1.large | ||||
|             'mac_address': 'aa:bb:cc:dd:ee:ff', | ||||
|             'os_type': 'linux'} | ||||
|         instance = db.instance_create(self.context, values) | ||||
| @@ -580,7 +580,7 @@ class XenAPIMigrateInstance(test.TestCase): | ||||
|                   'kernel_id': None, | ||||
|                   'ramdisk_id': None, | ||||
|                   'local_gb': 5, | ||||
|                   'instance_type': 'm1.large', | ||||
|                   'instance_type_id': '3',  # m1.large | ||||
|                   'mac_address': 'aa:bb:cc:dd:ee:ff', | ||||
|                   'os_type': 'linux'} | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Ken Pepple
					Ken Pepple