fix the skipped tests in vmwareapi xenapi and quota
This commit is contained in:
@@ -19,9 +19,6 @@
|
||||
Test suite for VMWareAPI.
|
||||
"""
|
||||
|
||||
import stubout
|
||||
|
||||
from nova import context
|
||||
from nova import db
|
||||
from nova import flags
|
||||
from nova import test
|
||||
@@ -41,51 +38,66 @@ FLAGS = flags.FLAGS
|
||||
class VMWareAPIVMTestCase(test.TestCase):
|
||||
"""Unit tests for Vmware API connection calls."""
|
||||
|
||||
# NOTE(jkoelker): This is leaking stubs into the db module.
|
||||
# Commenting out until updated for multi-nic.
|
||||
#def setUp(self):
|
||||
# super(VMWareAPIVMTestCase, self).setUp()
|
||||
# self.flags(vmwareapi_host_ip='test_url',
|
||||
# vmwareapi_host_username='test_username',
|
||||
# vmwareapi_host_password='test_pass')
|
||||
# self.manager = manager.AuthManager()
|
||||
# self.user = self.manager.create_user('fake', 'fake', 'fake',
|
||||
# admin=True)
|
||||
# self.project = self.manager.create_project('fake', 'fake', 'fake')
|
||||
# self.network = utils.import_object(FLAGS.network_manager)
|
||||
# self.stubs = stubout.StubOutForTesting()
|
||||
# vmwareapi_fake.reset()
|
||||
# db_fakes.stub_out_db_instance_api(self.stubs)
|
||||
# stubs.set_stubs(self.stubs)
|
||||
# glance_stubs.stubout_glance_client(self.stubs,
|
||||
# glance_stubs.FakeGlance)
|
||||
# self.conn = vmwareapi_conn.get_connection(False)
|
||||
def setUp(self):
|
||||
super(VMWareAPIVMTestCase, self).setUp()
|
||||
self.flags(vmwareapi_host_ip='test_url',
|
||||
vmwareapi_host_username='test_username',
|
||||
vmwareapi_host_password='test_pass')
|
||||
self.manager = manager.AuthManager()
|
||||
self.user = self.manager.create_user('fake', 'fake', 'fake',
|
||||
admin=True)
|
||||
self.project = self.manager.create_project('fake', 'fake', 'fake')
|
||||
self.network = utils.import_object(FLAGS.network_manager)
|
||||
vmwareapi_fake.reset()
|
||||
db_fakes.stub_out_db_instance_api(self.stubs)
|
||||
stubs.set_stubs(self.stubs)
|
||||
glance_stubs.stubout_glance_client(self.stubs)
|
||||
self.conn = vmwareapi_conn.get_connection(False)
|
||||
# NOTE(vish): none of the network plugging code is actually
|
||||
# being tested
|
||||
self.network_info = [({'bridge': 'fa0',
|
||||
'id': 0,
|
||||
'vlan': None,
|
||||
'bridge_interface': None,
|
||||
'injected': True},
|
||||
{'broadcast': '192.168.0.255',
|
||||
'dns': ['192.168.0.1'],
|
||||
'gateway': '192.168.0.1',
|
||||
'gateway6': 'dead:beef::1',
|
||||
'ip6s': [{'enabled': '1',
|
||||
'ip': 'dead:beef::dcad:beff:feef:0',
|
||||
'netmask': '64'}],
|
||||
'ips': [{'enabled': '1',
|
||||
'ip': '192.168.0.100',
|
||||
'netmask': '255.255.255.0'}],
|
||||
'label': 'fake',
|
||||
'mac': 'DE:AD:BE:EF:00:00',
|
||||
'rxtx_cap': 3})]
|
||||
|
||||
#def tearDown(self):
|
||||
# super(VMWareAPIVMTestCase, self).tearDown()
|
||||
# vmwareapi_fake.cleanup()
|
||||
# self.manager.delete_project(self.project)
|
||||
# self.manager.delete_user(self.user)
|
||||
# self.stubs.UnsetAll()
|
||||
def tearDown(self):
|
||||
super(VMWareAPIVMTestCase, self).tearDown()
|
||||
vmwareapi_fake.cleanup()
|
||||
self.manager.delete_project(self.project)
|
||||
self.manager.delete_user(self.user)
|
||||
|
||||
def _create_instance_in_the_db(self):
|
||||
values = {'name': 1,
|
||||
'id': 1,
|
||||
'project_id': self.project.id,
|
||||
'user_id': self.user.id,
|
||||
'image_id': "1",
|
||||
'image_ref': "1",
|
||||
'kernel_id': "1",
|
||||
'ramdisk_id': "1",
|
||||
'mac_address': "de:ad:be:ef:be:ef",
|
||||
'instance_type': 'm1.large',
|
||||
'mac_address': 'aa:bb:cc:dd:ee:ff',
|
||||
}
|
||||
self.instance = db.instance_create(values)
|
||||
self.instance = db.instance_create(None, values)
|
||||
|
||||
def _create_vm(self):
|
||||
"""Create and spawn the VM."""
|
||||
self._create_instance_in_the_db()
|
||||
self.type_data = db.instance_type_get_by_name(None, 'm1.large')
|
||||
self.conn.spawn(self.instance)
|
||||
self.conn.spawn(self.instance, self.network_info)
|
||||
self._check_vm_record()
|
||||
|
||||
def _check_vm_record(self):
|
||||
@@ -129,24 +141,20 @@ class VMWareAPIVMTestCase(test.TestCase):
|
||||
self.assertEquals(info["mem"], mem_kib)
|
||||
self.assertEquals(info["num_cpu"], self.type_data['vcpus'])
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_list_instances(self):
|
||||
instances = self.conn.list_instances()
|
||||
self.assertEquals(len(instances), 0)
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_list_instances_1(self):
|
||||
self._create_vm()
|
||||
instances = self.conn.list_instances()
|
||||
self.assertEquals(len(instances), 1)
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_spawn(self):
|
||||
self._create_vm()
|
||||
info = self.conn.get_info(1)
|
||||
self._check_vm_info(info, power_state.RUNNING)
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_snapshot(self):
|
||||
self._create_vm()
|
||||
info = self.conn.get_info(1)
|
||||
@@ -155,27 +163,23 @@ class VMWareAPIVMTestCase(test.TestCase):
|
||||
info = self.conn.get_info(1)
|
||||
self._check_vm_info(info, power_state.RUNNING)
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_snapshot_non_existent(self):
|
||||
self._create_instance_in_the_db()
|
||||
self.assertRaises(Exception, self.conn.snapshot, self.instance,
|
||||
"Test-Snapshot")
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_reboot(self):
|
||||
self._create_vm()
|
||||
info = self.conn.get_info(1)
|
||||
self._check_vm_info(info, power_state.RUNNING)
|
||||
self.conn.reboot(self.instance)
|
||||
self.conn.reboot(self.instance, self.network_info)
|
||||
info = self.conn.get_info(1)
|
||||
self._check_vm_info(info, power_state.RUNNING)
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_reboot_non_existent(self):
|
||||
self._create_instance_in_the_db()
|
||||
self.assertRaises(Exception, self.conn.reboot, self.instance)
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_reboot_not_poweredon(self):
|
||||
self._create_vm()
|
||||
info = self.conn.get_info(1)
|
||||
@@ -185,7 +189,6 @@ class VMWareAPIVMTestCase(test.TestCase):
|
||||
self._check_vm_info(info, power_state.PAUSED)
|
||||
self.assertRaises(Exception, self.conn.reboot, self.instance)
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_suspend(self):
|
||||
self._create_vm()
|
||||
info = self.conn.get_info(1)
|
||||
@@ -194,13 +197,11 @@ class VMWareAPIVMTestCase(test.TestCase):
|
||||
info = self.conn.get_info(1)
|
||||
self._check_vm_info(info, power_state.PAUSED)
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_suspend_non_existent(self):
|
||||
self._create_instance_in_the_db()
|
||||
self.assertRaises(Exception, self.conn.suspend, self.instance,
|
||||
self.dummy_callback_handler)
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_resume(self):
|
||||
self._create_vm()
|
||||
info = self.conn.get_info(1)
|
||||
@@ -212,13 +213,11 @@ class VMWareAPIVMTestCase(test.TestCase):
|
||||
info = self.conn.get_info(1)
|
||||
self._check_vm_info(info, power_state.RUNNING)
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_resume_non_existent(self):
|
||||
self._create_instance_in_the_db()
|
||||
self.assertRaises(Exception, self.conn.resume, self.instance,
|
||||
self.dummy_callback_handler)
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_resume_not_suspended(self):
|
||||
self._create_vm()
|
||||
info = self.conn.get_info(1)
|
||||
@@ -226,49 +225,41 @@ class VMWareAPIVMTestCase(test.TestCase):
|
||||
self.assertRaises(Exception, self.conn.resume, self.instance,
|
||||
self.dummy_callback_handler)
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_get_info(self):
|
||||
self._create_vm()
|
||||
info = self.conn.get_info(1)
|
||||
self._check_vm_info(info, power_state.RUNNING)
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_destroy(self):
|
||||
self._create_vm()
|
||||
info = self.conn.get_info(1)
|
||||
self._check_vm_info(info, power_state.RUNNING)
|
||||
instances = self.conn.list_instances()
|
||||
self.assertEquals(len(instances), 1)
|
||||
self.conn.destroy(self.instance)
|
||||
self.conn.destroy(self.instance, self.network_info)
|
||||
instances = self.conn.list_instances()
|
||||
self.assertEquals(len(instances), 0)
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_destroy_non_existent(self):
|
||||
self._create_instance_in_the_db()
|
||||
self.assertEquals(self.conn.destroy(self.instance), None)
|
||||
self.assertEquals(self.conn.destroy(self.instance, self.network_info),
|
||||
None)
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_pause(self):
|
||||
pass
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_unpause(self):
|
||||
pass
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_diagnostics(self):
|
||||
pass
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_get_console_output(self):
|
||||
pass
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def test_get_ajax_console(self):
|
||||
pass
|
||||
|
||||
@test.skip_test("DB stubbing not removed, needs updating for multi-nic")
|
||||
def dummy_callback_handler(self, ret):
|
||||
"""
|
||||
Dummy callback function to be passed to suspend, resume, etc., calls.
|
||||
|
@@ -396,18 +396,22 @@ class XenAPIVMTestCase(test.TestCase):
|
||||
def _test_spawn(self, image_ref, kernel_id, ramdisk_id,
|
||||
instance_type_id="3", os_type="linux",
|
||||
architecture="x86-64", instance_id=1,
|
||||
check_injection=False):
|
||||
check_injection=False,
|
||||
create_record=True):
|
||||
stubs.stubout_loopingcall_start(self.stubs)
|
||||
values = {'id': instance_id,
|
||||
'project_id': self.project.id,
|
||||
'user_id': self.user.id,
|
||||
'image_ref': image_ref,
|
||||
'kernel_id': kernel_id,
|
||||
'ramdisk_id': ramdisk_id,
|
||||
'instance_type_id': instance_type_id,
|
||||
'os_type': os_type,
|
||||
'architecture': architecture}
|
||||
instance = db.instance_create(self.context, values)
|
||||
if create_record:
|
||||
values = {'id': instance_id,
|
||||
'project_id': self.project.id,
|
||||
'user_id': self.user.id,
|
||||
'image_ref': image_ref,
|
||||
'kernel_id': kernel_id,
|
||||
'ramdisk_id': ramdisk_id,
|
||||
'instance_type_id': instance_type_id,
|
||||
'os_type': os_type,
|
||||
'architecture': architecture}
|
||||
instance = db.instance_create(self.context, values)
|
||||
else:
|
||||
instance = db.instance_get(self.context, instance_id)
|
||||
network_info = [({'bridge': 'fa0', 'id': 0, 'injected': True},
|
||||
{'broadcast': '192.168.0.255',
|
||||
'dns': ['192.168.0.1'],
|
||||
@@ -599,41 +603,38 @@ class XenAPIVMTestCase(test.TestCase):
|
||||
# guest agent is detected
|
||||
self.assertFalse(self._tee_executed)
|
||||
|
||||
@test.skip_test("Never gets an address, not sure why")
|
||||
def test_spawn_vlanmanager(self):
|
||||
self.flags(xenapi_image_service='glance',
|
||||
network_manager='nova.network.manager.VlanManager',
|
||||
network_driver='nova.network.xenapi_net',
|
||||
vlan_interface='fake0')
|
||||
|
||||
def dummy(*args, **kwargs):
|
||||
pass
|
||||
|
||||
self.stubs.Set(VMOps, 'create_vifs', dummy)
|
||||
self.stubs.Set(vmops.VMOps, 'create_vifs', dummy)
|
||||
# Reset network table
|
||||
xenapi_fake.reset_table('network')
|
||||
# Instance id = 2 will use vlan network (see db/fakes.py)
|
||||
ctxt = self.context.elevated()
|
||||
instance_ref = self._create_instance(2)
|
||||
network_bk = self.network
|
||||
# Ensure we use xenapi_net driver
|
||||
self.network = utils.import_object(FLAGS.network_manager)
|
||||
instance = self._create_instance(2, False)
|
||||
networks = self.network.db.network_get_all(ctxt)
|
||||
for network in networks:
|
||||
self.network.set_network_host(ctxt, network['id'])
|
||||
self.network.set_network_host(ctxt, network)
|
||||
|
||||
self.network.allocate_for_instance(ctxt, instance_id=instance_ref.id,
|
||||
instance_type_id=1, project_id=self.project.id)
|
||||
self.network.setup_compute_network(ctxt, instance_ref.id)
|
||||
self.network.allocate_for_instance(ctxt,
|
||||
instance_id=2,
|
||||
host=FLAGS.host,
|
||||
vpn=None,
|
||||
instance_type_id=1,
|
||||
project_id=self.project.id)
|
||||
self._test_spawn(glance_stubs.FakeGlance.IMAGE_MACHINE,
|
||||
glance_stubs.FakeGlance.IMAGE_KERNEL,
|
||||
glance_stubs.FakeGlance.IMAGE_RAMDISK,
|
||||
instance_id=instance_ref.id,
|
||||
instance_id=2,
|
||||
create_record=False)
|
||||
# TODO(salvatore-orlando): a complete test here would require
|
||||
# a check for making sure the bridge for the VM's VIF is
|
||||
# consistent with bridge specified in nova db
|
||||
self.network = network_bk
|
||||
|
||||
def test_spawn_with_network_qos(self):
|
||||
self._create_instance()
|
||||
@@ -663,7 +664,7 @@ class XenAPIVMTestCase(test.TestCase):
|
||||
self.vm = None
|
||||
self.stubs.UnsetAll()
|
||||
|
||||
def _create_instance(self, instance_id=1):
|
||||
def _create_instance(self, instance_id=1, spawn=True):
|
||||
"""Creates and spawns a test instance."""
|
||||
stubs.stubout_loopingcall_start(self.stubs)
|
||||
values = {
|
||||
@@ -691,7 +692,8 @@ class XenAPIVMTestCase(test.TestCase):
|
||||
'label': 'fake',
|
||||
'mac': 'DE:AD:BE:EF:00:00',
|
||||
'rxtx_cap': 3})]
|
||||
self.conn.spawn(instance, network_info)
|
||||
if spawn:
|
||||
self.conn.spawn(instance, network_info)
|
||||
return instance
|
||||
|
||||
|
||||
|
@@ -70,8 +70,8 @@ def stub_out_db_instance_api(stubs):
|
||||
'launch_time': time.strftime('%Y-%m-%dT%H:%M:%SZ', time.gmtime()),
|
||||
'instance_type': values['instance_type'],
|
||||
'memory_mb': type_data['memory_mb'],
|
||||
'mac_address': values['mac_address'],
|
||||
'vcpus': type_data['vcpus'],
|
||||
'mac_addresses': [{'address': values['mac_address']}],
|
||||
'local_gb': type_data['local_gb'],
|
||||
}
|
||||
return FakeModel(base_options)
|
||||
@@ -83,6 +83,8 @@ def stub_out_db_instance_api(stubs):
|
||||
'bridge': 'vmnet0',
|
||||
'netmask': '255.255.255.0',
|
||||
'gateway': '10.10.10.1',
|
||||
'broadcast': '10.10.10.255',
|
||||
'dns1': 'fake',
|
||||
'vlan': 100}
|
||||
return FakeModel(fields)
|
||||
|
||||
@@ -90,7 +92,7 @@ def stub_out_db_instance_api(stubs):
|
||||
"""Stubs out the db.instance_action_create method."""
|
||||
pass
|
||||
|
||||
def fake_instance_get_fixed_address(context, instance_id):
|
||||
def fake_instance_get_fixed_addresses(context, instance_id):
|
||||
"""Stubs out the db.instance_get_fixed_address method."""
|
||||
return '10.10.10.10'
|
||||
|
||||
@@ -103,7 +105,7 @@ def stub_out_db_instance_api(stubs):
|
||||
stubs.Set(db, 'instance_create', fake_instance_create)
|
||||
stubs.Set(db, 'network_get_by_instance', fake_network_get_by_instance)
|
||||
stubs.Set(db, 'instance_action_create', fake_instance_action_create)
|
||||
stubs.Set(db, 'instance_get_fixed_address',
|
||||
fake_instance_get_fixed_address)
|
||||
stubs.Set(db, 'instance_get_fixed_addresses',
|
||||
fake_instance_get_fixed_addresses)
|
||||
stubs.Set(db, 'instance_type_get_all', fake_instance_type_get_all)
|
||||
stubs.Set(db, 'instance_type_get_by_name', fake_instance_type_get_by_name)
|
||||
|
@@ -22,6 +22,8 @@ Stubouts for the test suite
|
||||
from nova.virt import vmwareapi_conn
|
||||
from nova.virt.vmwareapi import fake
|
||||
from nova.virt.vmwareapi import vmware_images
|
||||
from nova.virt.vmwareapi import vmops
|
||||
from nova.virt.vmwareapi import network_utils
|
||||
|
||||
|
||||
def fake_get_vim_object(arg):
|
||||
@@ -36,10 +38,15 @@ def fake_is_vim_object(arg, module):
|
||||
|
||||
def set_stubs(stubs):
|
||||
"""Set the stubs."""
|
||||
stubs.Set(vmops.VMWareVMOps, 'plug_vifs', fake.fake_plug_vifs)
|
||||
stubs.Set(network_utils, 'get_network_with_the_name',
|
||||
fake.fake_get_network)
|
||||
stubs.Set(vmware_images, 'fetch_image', fake.fake_fetch_image)
|
||||
stubs.Set(vmware_images, 'get_vmdk_size_and_properties',
|
||||
fake.fake_get_vmdk_size_and_properties)
|
||||
stubs.Set(vmware_images, 'upload_image', fake.fake_upload_image)
|
||||
stubs.Set(vmwareapi_conn.VMWareAPISession, "_get_vim_object",
|
||||
fake_get_vim_object)
|
||||
stubs.Set(vmwareapi_conn.VMWareAPISession, "_get_vim_object",
|
||||
fake_get_vim_object)
|
||||
stubs.Set(vmwareapi_conn.VMWareAPISession, "_is_vim_object",
|
||||
|
Reference in New Issue
Block a user