summaryrefslogtreecommitdiffstats
path: root/nova/tests
diff options
context:
space:
mode:
authorJenkins <jenkins@review.openstack.org>2013-03-06 01:03:51 +0000
committerGerrit Code Review <review@openstack.org>2013-03-06 01:03:51 +0000
commit63e9a7edd9e4b488d4fe74cf922c405e0b8094ab (patch)
tree1166ca0f70aa7fe73df554cf0050303b96a5ef2f /nova/tests
parent05bc166ce92b72dc88ff997a3c3cdca34b135861 (diff)
parent689e9e3e3d48928fe950b26745a7df6fee2f0718 (diff)
Merge "Fixes disk size issue during image boot on Hyper-V"
Diffstat (limited to 'nova/tests')
-rw-r--r--nova/tests/hyperv/db_fakes.py7
-rw-r--r--nova/tests/test_hypervapi.py30
2 files changed, 29 insertions, 8 deletions
diff --git a/nova/tests/hyperv/db_fakes.py b/nova/tests/hyperv/db_fakes.py
index 7169edf8d..5152bd035 100644
--- a/nova/tests/hyperv/db_fakes.py
+++ b/nova/tests/hyperv/db_fakes.py
@@ -41,7 +41,7 @@ def get_fake_instance_data(name, project_id, user_id):
{'name': 'm1.tiny',
'memory_mb': 512,
'vcpus': 1,
- 'root_gb': 0,
+ 'root_gb': 1024,
'flavorid': 1,
'rxtx_factor': 1}
}
@@ -69,8 +69,6 @@ def get_fake_volume_info_data(target_portal, volume_id):
'target_portal': target_portal,
'target_lun': 1,
'auth_method': 'CHAP',
- 'auth_method': 'fake',
- 'auth_method': 'fake',
}
}
@@ -121,6 +119,9 @@ def stub_out_db_instance_api(stubs):
def __getitem__(self, key):
return self.get(key)
+ def __setitem__(self, key, value):
+ self.values[key] = value
+
def __str__(self):
return str(self.values)
diff --git a/nova/tests/test_hypervapi.py b/nova/tests/test_hypervapi.py
index aaceff8ec..5dc77b911 100644
--- a/nova/tests/test_hypervapi.py
+++ b/nova/tests/test_hypervapi.py
@@ -154,6 +154,8 @@ class HyperVAPITestCase(test.TestCase):
self._mox.StubOutWithMock(vhdutils.VHDUtils, 'merge_vhd')
self._mox.StubOutWithMock(vhdutils.VHDUtils, 'get_vhd_parent_path')
self._mox.StubOutWithMock(vhdutils.VHDUtils, 'get_vhd_info')
+ self._mox.StubOutWithMock(vhdutils.VHDUtils, 'resize_vhd')
+ self._mox.StubOutWithMock(vhdutils.VHDUtils, 'validate_vhd')
self._mox.StubOutWithMock(hostutils.HostUtils, 'get_cpus_info')
self._mox.StubOutWithMock(hostutils.HostUtils,
@@ -567,6 +569,8 @@ class HyperVAPITestCase(test.TestCase):
self.flags(use_cow_images=cow)
instance_data = self._get_instance_data()
+ instance = db.instance_create(self._context, instance_data)
+ instance['system_metadata'] = {}
network_info = fake_network.fake_get_instance_nw_info(self.stubs,
spectacular=True)
@@ -579,10 +583,14 @@ class HyperVAPITestCase(test.TestCase):
None)
m.AndReturn(False)
- vhdutils.VHDUtils.get_vhd_info(mox.Func(self._check_img_path))
+ m = vhdutils.VHDUtils.get_vhd_info(mox.Func(self._check_img_path))
+ m.AndReturn({'MaxInternalSize': 1024})
+
+ fake.PathUtils.copyfile(mox.IsA(str), mox.IsA(str))
+ vhdutils.VHDUtils.resize_vhd(mox.IsA(str), mox.IsA(object))
self._mox.ReplayAll()
- self._conn.pre_live_migration(self._context, instance_data,
+ self._conn.pre_live_migration(self._context, instance,
None, network_info)
self._mox.VerifyAll()
@@ -697,6 +705,7 @@ class HyperVAPITestCase(test.TestCase):
self._instance_data = self._get_instance_data()
instance = db.instance_create(self._context, self._instance_data)
+ instance['system_metadata'] = {}
image = db_fakes.get_fake_image_data(self._project_id, self._user_id)
@@ -763,12 +772,16 @@ class HyperVAPITestCase(test.TestCase):
m.AndReturn(boot_from_volume)
if not boot_from_volume:
- vhdutils.VHDUtils.get_vhd_info(mox.Func(self._check_img_path))
+ m = vhdutils.VHDUtils.get_vhd_info(mox.Func(self._check_img_path))
+ m.AndReturn({'MaxInternalSize': 1024})
if cow:
- vhdutils.VHDUtils.create_differencing_vhd(
- mox.IsA(str), mox.Func(self._check_img_path))
+ fake.PathUtils.copyfile(mox.IsA(str), mox.IsA(str))
+ vhdutils.VHDUtils.resize_vhd(mox.IsA(str), mox.IsA(object))
+ vhdutils.VHDUtils.create_differencing_vhd(mox.IsA(str),
+ mox.IsA(str))
else:
+ vhdutils.VHDUtils.resize_vhd(mox.IsA(str), mox.IsA(object))
fake.PathUtils.copyfile(mox.IsA(str), mox.IsA(str))
self._setup_create_instance_mocks(setup_vif_mocks_func,
@@ -1009,6 +1022,7 @@ class HyperVAPITestCase(test.TestCase):
def test_finish_migration(self):
self._instance_data = self._get_instance_data()
instance = db.instance_create(self._context, self._instance_data)
+ instance['system_metadata'] = {}
network_info = fake_network.fake_get_instance_nw_info(
self.stubs, spectacular=True)
@@ -1032,6 +1046,12 @@ class HyperVAPITestCase(test.TestCase):
vhdutils.VHDUtils.reconnect_parent_vhd(mox.IsA(str), mox.IsA(str))
+ m = vhdutils.VHDUtils.get_vhd_info(mox.IsA(str))
+ m.AndReturn({'MaxInternalSize': 1024})
+
+ m = fake.PathUtils.exists(mox.IsA(str))
+ m.AndReturn(True)
+
self._set_vm_name(instance['name'])
self._setup_create_instance_mocks(None, False)