Fix image_id in instance resource metadata

Originally the image property in instance resource metadata is correct
since instance information is fetched from db access.

After switching to nova client api, these information is lost
since the returned data format from nova client is different with db
access result.

Image ref and image url is fixed with this patch while kernel_id and
ramdisk_id should be fixed in nova side.

For bug 1090310

Change-Id: I51816b4bd31c09a59e1ef857f8981a45f33f68dc
Signed-off-by: Yunhong, Jiang <yunhong.jiang@intel.com>
This commit is contained in:
Yunhong, Jiang 2012-12-17 15:58:45 +08:00
parent 23ff2f9bbf
commit 4356ab20a3
2 changed files with 26 additions and 11 deletions

View File

@ -25,9 +25,6 @@ INSTANCE_PROPERTIES = [
'architecture', 'architecture',
# Location properties # Location properties
'availability_zone', 'availability_zone',
# Image properties
'image_ref',
'image_ref_url',
'kernel_id', 'kernel_id',
'os_type', 'os_type',
'ramdisk_id', 'ramdisk_id',
@ -48,6 +45,10 @@ def get_metadata_from_object(instance):
'name': getattr(instance, 'OS-EXT-SRV-ATTR:instance_name', u''), 'name': getattr(instance, 'OS-EXT-SRV-ATTR:instance_name', u''),
'instance_type': (instance.flavor['id'] if instance.flavor else None), 'instance_type': (instance.flavor['id'] if instance.flavor else None),
'host': instance.hostId, 'host': instance.hostId,
# Image properties
'image_ref': (instance.image['id'] if instance.image else None),
'image_ref_url': (instance.image['links'][0]['href']
if instance.image else None),
} }
for name in INSTANCE_PROPERTIES: for name in INSTANCE_PROPERTIES:

View File

@ -44,14 +44,16 @@ class FauxInstance(object):
class TestLocationMetadata(unittest.TestCase): class TestLocationMetadata(unittest.TestCase):
# Mimics an instance returned from nova api call def setUp(self):
INSTANCE_PROPERTIES = {'name': 'display name', self.manager = manager.AgentManager()
super(TestLocationMetadata, self).setUp()
# Mimics an instance returned from nova api call
self.INSTANCE_PROPERTIES = {'name': 'display name',
'OS-EXT-SRV-ATTR:instance_name': 'instance-000001', 'OS-EXT-SRV-ATTR:instance_name': 'instance-000001',
'reservation_id': 'reservation id', 'reservation_id': 'reservation id',
'architecture': 'x86_64', 'architecture': 'x86_64',
'availability_zone': 'zone1', 'availability_zone': 'zone1',
'image_ref': 'image ref',
'image_ref_url': 'image ref url',
'kernel_id': 'kernel id', 'kernel_id': 'kernel id',
'os_type': 'linux', 'os_type': 'linux',
'ramdisk_id': 'ramdisk id', 'ramdisk_id': 'ramdisk id',
@ -60,13 +62,14 @@ class TestLocationMetadata(unittest.TestCase):
'memory_mb': 2048, 'memory_mb': 2048,
'root_gb': 3, 'root_gb': 3,
'vcpus': 1, 'vcpus': 1,
'image': {'id': 1,
'links': [{"rel": "bookmark",
'href': 2}],
},
'flavor': {'id': 1}, 'flavor': {'id': 1},
'hostId': '1234-5678' 'hostId': '1234-5678',
} }
def setUp(self):
self.manager = manager.AgentManager()
super(TestLocationMetadata, self).setUp()
self.instance = FauxInstance(**self.INSTANCE_PROPERTIES) self.instance = FauxInstance(**self.INSTANCE_PROPERTIES)
self.instance.host = 'made-up-hostname' self.instance.host = 'made-up-hostname'
m = mock.MagicMock() m = mock.MagicMock()
@ -87,5 +90,16 @@ class TestLocationMetadata(unittest.TestCase):
assert actual == iprops['name'] assert actual == iprops['name']
elif name == 'instance_type': elif name == 'instance_type':
assert actual == iprops['flavor']['id'] assert actual == iprops['flavor']['id']
elif name == 'image_ref':
assert actual == iprops['image']['id']
elif name == 'image_ref_url':
assert actual == iprops['image']['links'][0]['href']
else: else:
assert actual == iprops[name] assert actual == iprops[name]
def test_metadata_empty_image(self):
self.INSTANCE_PROPERTIES['image'] = ''
self.instance = FauxInstance(**self.INSTANCE_PROPERTIES)
md = instance.get_metadata_from_object(self.instance)
assert md['image_ref'] == None
assert md['image_ref_url'] == None