def test_live_migration_for_windows_instance(self):
"""This test checks that instance with Windows Image could be
migrated without any issues
Steps:
1. Upload Windows 2012 Server image to Glance
2. Create VM with this Windows image
3. Assign floating IP to this VM
4. Ping this VM and verify that we can ping it
5. Migrate this VM to another compute node
6. Verify that live Migration works fine for Windows VMs
and we can successfully ping this VM
7. Reboot VM and verify that
we can successfully ping this VM after reboot.
:return: Nothing
"""
# 1. 2. 3. -> Into setUp function
# 4. Ping this VM and verify that we can ping it
hypervisor_hostname_attribute = "OS-EXT-SRV-ATTR:hypervisor_hostname"
ping_result = common_functions.ping_command(self.floating_ip.ip)
self.assertTrue(ping_result, "Instance is not reachable")
hypervisors = {h.hypervisor_hostname: h for h in self.nova.hypervisors.list()}
old_hyper = getattr(self.instance, hypervisor_hostname_attribute)
logger.info("Old hypervisor is: {}".format(old_hyper))
new_hyper = [h for h in hypervisors.keys() if h != old_hyper][0]
logger.info("New hypervisor is: {}".format(new_hyper))
# Execute the live migrate
self.instance.live_migrate(new_hyper, block_migration=True)
self.instance = self.nova.servers.get(self.instance.id)
end_time = time.time() + 60 * self.hypervisor_timeout
debug_string = "Waiting for changes."
while getattr(self.instance, hypervisor_hostname_attribute) != new_hyper:
if time.time() > end_time:
# it can fail because of this issue
# https://bugs.launchpad.net/mos/+bug/1544564
logger.info(debug_string)
raise AssertionError("Hypervisor is not changed after live migration")
time.sleep(30)
debug_string += "."
self.instance = self.nova.servers.get(self.instance.id)
logger.info(debug_string)
self.assertEqual(self.instance.status, "ACTIVE")
# Ping the Virtual Machine
ping_result = common_functions.ping_command(self.floating_ip.ip)
self.assertTrue(ping_result, "Instance is not reachable")
# Reboot the VM and make sure that we can ping it
self.instance.reboot(reboot_type="HARD")
instance_status = common_functions.check_inst_status(self.nova, self.instance.id, "ACTIVE")
self.instance = [s for s in self.nova.servers.list() if s.id == self.instance.id][0]
if not instance_status:
raise AssertionError("Instance status is '{0}' instead of 'ACTIVE".format(self.instance.status))
self.wait_instance_to_boot()
# Waiting for up-and-run of Virtual Machine after reboot
ping_result = common_functions.ping_command(self.floating_ip.ip)
self.assertTrue(ping_result, "Instance is not reachable")
def test_suspend_and_resume_instance_with_windows_image(self):
"""This test checks that instance with Windows image can be suspended
and resumed
Steps:
1. Upload Windows 2012 Server image to Glance
2. Create VM with this Windows image
3. Assign floating IP to this VM
4. Ping this VM and verify that we can ping it
5. Suspend VM
6. Verify that we can't ping it
7. Resume and verify that we can ping it again.
8. Reboot VM
9. Verify that we can ping this VM after reboot.
:return: Nothing
"""
# Initial check
ping_result = common_functions.ping_command(self.floating_ip.ip)
self.assertTrue(ping_result, "Instance is not reachable")
# Suspend state check
self.instance.suspend()
# Make sure that the VM in 'Suspended' state
ping_result = common_functions.ping_command(
self.floating_ip.ip,
should_be_available=False
)
self.assertTrue(ping_result, "Instance is reachable")
# Resume state check
self.instance.resume()
# Make sure that the VM in 'Resume' state
ping_result = common_functions.ping_command(self.floating_ip.ip)
self.assertTrue(ping_result, "Instance is not reachable")
# Reboot the VM and make sure that we can ping it
self.instance.reboot(reboot_type='HARD')
instance_status = common_functions.check_inst_status(
self.nova,
self.instance.id,
'ACTIVE')
self.instance = [s for s in self.nova.servers.list()
if s.id == self.instance.id][0]
if not instance_status:
raise AssertionError(
"Instance status is '{0}' instead of 'ACTIVE".format(
self.instance.status))
self.wait_instance_to_boot()
# Waiting for up-and-run of Virtual Machine after reboot
ping_result = common_functions.ping_command(self.floating_ip.ip)
self.assertTrue(ping_result, "Instance is not reachable")
def test_pause_and_unpause_instance_with_windows_image(self, instance,
floating_ip):
"""This test checks that instance with Windows image could be paused
and unpaused
Steps:
1. Upload Windows 2012 Server image to Glance
2. Create VM with this Windows image
3. Assign floating IP to this VM
4. Ping this VM and verify that we can ping it
5. Pause this VM
6. Verify that we can't ping it
7. Unpause it and verify that we can ping it again
8. Reboot VM
9. Verify that we can ping this VM after reboot.
:return: Nothing
"""
# Initial check
ping_result = common.ping_command(floating_ip.ip)
assert ping_result, "Instance is not reachable"
# Paused state check
instance.pause()
# Make sure that the VM in 'Paused' state
ping_result = common.ping_command(floating_ip.ip,
should_be_available=False)
assert ping_result, "Instance is reachable"
# Unpaused state check
instance.unpause()
# Make sure that the VM in 'Unpaused' state
ping_result = common.ping_command(floating_ip.ip)
assert ping_result, "Instance is not reachable"
# Reboot the VM and make sure that we can ping it
instance.reboot(reboot_type='HARD')
instance_status = common.check_inst_status(
self.os_conn.nova,
instance.id,
'ACTIVE')
instance = self.os_conn.nova.servers.get(instance.id)
if not instance_status:
raise AssertionError(
"Instance status is '{0}' instead of 'ACTIVE".format(
instance.status))
self.wait_to_boot(instance)
# Waiting for up-and-run of Virtual Machine after reboot
ping_result = common.ping_command(floating_ip.ip)
assert ping_result, "Instance is not reachable"
def test_542826_PauseAndUnpauseInstanceWithWindowsImage(self):
""" This test checks that instance with Windows image could be paused
and unpaused
Steps:
1. Upload Windows 2012 Server image to Glance
2. Create VM with this Windows image
3. Assign floating IP to this VM
4. Ping this VM and verify that we can ping it
5. Pause this VM
6. Verify that we can't ping it
7. Unpause it and verify that we can ping it again
8. Reboot VM
9. Verify that we can ping this VM after reboot.
:return: Nothing
"""
# Initial check
ping_result = common_functions.ping_command(self.floating_ip.ip)
self.assertTrue(ping_result, "Instance is not reachable")
# Paused state check
self.node_to_boot.pause()
# Make sure that the VM in 'Paused' state
ping_result = common_functions.ping_command(
self.floating_ip.ip,
should_be_available=False
)
self.assertTrue(ping_result, "Instance is reachable")
# Unpaused state check
self.node_to_boot.unpause()
# Make sure that the VM in 'Unpaused' state
ping_result = common_functions.ping_command(self.floating_ip.ip)
self.assertTrue(ping_result, "Instance is not reachable")
# Reboot the VM and make sure that we can ping it
self.node_to_boot.reboot(reboot_type='HARD')
instance_status = common_functions.check_inst_status(
self.nova,
self.node_to_boot.id,
'ACTIVE')
self.node_to_boot = [s for s in self.nova.servers.list()
if s.id == self.node_to_boot.id][0]
if not instance_status:
raise AssertionError(
"Instance status is '{0}' instead of 'ACTIVE".format(
self.node_to_boot.status))
# Waiting for up-and-run of Virtual Machine after reboot
ping_result = common_functions.ping_command(self.floating_ip.ip)
self.assertTrue(ping_result, "Instance is not reachable")
def test_nova_massively_spawn_v_ms_with_boot_local(self):
"""This test case creates a lot of VMs with boot local, checks it
state and availability and then deletes it.
Steps:
1. Boot 10-100 instances from image.
2. Check that list of instances contains created VMs.
3. Check state of created instances
4. Add the floating ips to the instances
5. Ping the instances by the floating ips
"""
initial_instances = self.nova.servers.list()
primary_name = "testVM_543356"
count = 10
image_dict = {im.name: im.id for im in self.nova.images.list()}
image_id = image_dict["TestVM"]
flavor_dict = {f.name: f.id for f in self.nova.flavors.list()}
flavor_id = flavor_dict["m1.micro"]
networks = self.neutron.list_networks()["networks"]
net_dict = {net["name"]: net["id"] for net in networks}
net_internal_id = net_dict["admin_internal_net"]
self.floating_ips = [self.nova.floating_ips.create()
for _ in xrange(count)]
fip_new = [fip_info.ip for fip_info in self.floating_ips]
fip_all = [fip_info.ip for fip_info in self.nova.floating_ips.list()]
for fip in fip_new:
self.assertIn(fip, fip_all)
self.nova.servers.create(primary_name, image_id, flavor_id,
max_count=count,
security_groups=[self.sec_group.name],
nics=[{"net-id": net_internal_id}])
start_time = time()
timeout = 5
while len(self.nova.servers.list()) < len(initial_instances) + count \
and time() < start_time + timeout * 60:
sleep(5)
instances = [inst for inst in self.nova.servers.list()
if inst not in initial_instances]
self.instances = [inst.id for inst in instances]
for inst_id in self.instances:
self.assertTrue(common_functions.check_inst_status(self.nova,
inst_id,
'ACTIVE'))
fip_dict = {}
for inst in instances:
fip = fip_new.pop()
inst.add_floating_ip(fip)
fip_dict[inst.id] = fip
for inst_id in self.instances:
self.assertTrue(common_functions.check_ip(
self.nova, inst_id, fip_dict[inst_id]))
for inst_id in self.instances:
ping = common_functions.ping_command(fip_dict[inst_id], i=8)
self.assertTrue(ping,
"Instance {} is not reachable".format(inst_id))
def test_network_connectivity_to_v_m_during_live_migration(self):
"""This test checks network connectivity to VM during Live Migration
Steps:
1. Create a floating ip
2. Create an instance from an image with 'm1.micro' flavor
3. Add the floating ip to the instance
4. Ping the instance by the floating ip
5. Execute live migration
6. Check current hypervisor and status of instance
7. Check that packets loss was minimal
"""
net = self.get_admin_int_net_id()
image_id = [image.id for image in self.nova.images.list() if
image.name == 'TestVM'][0]
flavor = [flavor for flavor in self.nova.flavors.list() if
flavor.name == 'm1.micro'][0]
floating_ip = self.nova.floating_ips.create()
self.floating_ips.append(floating_ip)
self.assertIn(floating_ip.ip, [fip_info.ip for fip_info in
self.nova.floating_ips.list()])
inst = common_functions.create_instance(self.nova,
"inst_2238776_{}"
.format(flavor.name),
flavor.id, net,
[self.sec_group.id],
image_id=image_id,
inst_list=self.instances)
self.instances.append(inst.id)
inst.add_floating_ip(floating_ip.ip)
ping = common_functions.ping_command(floating_ip.ip)
self.assertTrue(ping, "Instance is not reachable")
self.live_migration(inst, floating_ip.ip)
def test_network_connectivity_to_v_m_during_live_migration(self):
"""This test checks network connectivity to VM during Live Migration
Steps:
1. Create a floating ip
2. Create an instance from an image with 'm1.micro' flavor
3. Add the floating ip to the instance
4. Ping the instance by the floating ip
5. Execute live migration
6. Check current hypervisor and status of instance
7. Check that packets loss was minimal
"""
networks = self.neutron.list_networks()['networks']
net = [net['id'] for net in networks if not net['router:external']][0]
image_id = [image.id for image in self.nova.images.list() if
image.name == 'TestVM'][0]
flavor = [flavor for flavor in self.nova.flavors.list() if
flavor.name == 'm1.micro'][0]
floating_ip = self.nova.floating_ips.create()
self.floating_ips.append(floating_ip)
self.assertIn(floating_ip.ip, [fip_info.ip for fip_info in
self.nova.floating_ips.list()])
inst = common_functions.create_instance(self.nova,
"inst_2238776_{}"
.format(flavor.name),
flavor.id, net,
[self.sec_group.name],
image_id=image_id,
inst_list=self.instances)
self.instances.append(inst.id)
inst.add_floating_ip(floating_ip.ip)
ping = common_functions.ping_command(floating_ip.ip)
self.assertTrue(ping, "Instance is not reachable")
hypervisors = {h.hypervisor_hostname: h for h
in self.nova.hypervisors.list()}
old_hyper = getattr(inst, "OS-EXT-SRV-ATTR:hypervisor_hostname")
new_hyper = [h for h in hypervisors.keys() if h != old_hyper][0]
ping = subprocess.Popen(["/bin/ping", "-c100", "-i1", floating_ip.ip],
stdout=subprocess.PIPE)
self.nova.servers.live_migrate(inst, new_hyper, block_migration=False,
disk_over_commit=False)
inst = self.nova.servers.get(inst.id)
timeout = 5
end_time = time() + 60 * timeout
while getattr(inst, "OS-EXT-SRV-ATTR:hypervisor_hostname") != \
new_hyper:
if time() > end_time:
msg = "Hypervisor is not changed after live migration"
raise AssertionError(msg)
sleep(1)
inst = self.nova.servers.get(inst.id)
self.assertEqual(inst.status, 'ACTIVE')
ping.wait()
output = ping.stdout.read().split('\n')[-3].split()
packets = {'transmitted': int(output[0]), 'received': int(output[3])}
loss = packets['transmitted'] - packets['received']
if loss > 5:
msg = "Packets loss exceeds the limit, {} packets were lost"
raise AssertionError(msg.format(loss))
def test_create_instance_with_windows_image(self, request, floating_ip):
"""This test checks that instance with Windows image could be created
Steps:
1. Upload Windows 2012 Server image to Glance
2. Create VM with this Windows image
3. Assign floating IP to this VM
4. Ping this VM and verify that we can ping it
"""
request.getfuncargvalue("instance")
ping_result = common.ping_command(floating_ip.ip)
assert ping_result, "Instance is not reachable"
def test_create_instance_with_windows_image(self):
"""This test checks that instance with Windows image could be created
Steps:
1. Upload Windows 2012 Server image to Glance
2. Create VM with this Windows image
3. Assign floating IP to this VM
4. Ping this VM and verify that we can ping it
:return: Nothing
"""
ping_result = common_functions.ping_command(self.floating_ip.ip)
self.assertTrue(ping_result, "Instance is not reachable")
def test_nova_launch_v_m_from_volume_with_all_flavours(self):
"""This test case checks creation of instance from volume with all
types of flavor. For this test needs 2 nodes with compute role:
20Gb RAM and 150GB disk for each
Steps:
1. Create bootable volume
1. Create a floating ip
2. Create an instance from an image with some flavor
3. Add the floating ip to the instance
4. Ping the instance by the floating ip
5. Delete the floating ip
6. delete the instance
7. Repeat all steps for all types of flavor
"""
image_id = [image.id for image in self.nova.images.list() if
image.name == 'TestVM'][0]
networks = self.neutron.list_networks()['networks']
net = [net['id'] for net in networks if not net['router:external']][0]
flavor_list = self.nova.flavors.list()
for flavor in flavor_list:
floating_ip = self.nova.floating_ips.create()
self.floating_ips.append(floating_ip)
self.assertIn(floating_ip.ip, [fip_info.ip for fip_info in
self.nova.floating_ips.list()])
volume = common_functions.create_volume(self.cinder, image_id)
self.volumes.append(volume)
bdm = {'vda': volume.id}
inst = common_functions.create_instance(self.nova,
"inst_543360_{}"
.format(flavor.name),
flavor.id, net,
[self.sec_group.name],
block_device_mapping=bdm,
inst_list=self.instances)
inst_id = inst.id
self.instances.append(inst_id)
inst.add_floating_ip(floating_ip.ip)
self.assertTrue(common_functions.check_ip(self.nova, inst_id,
floating_ip.ip))
ping = common_functions.ping_command(floating_ip.ip)
self.assertTrue(ping, "Instance is not reachable")
def test_nova_launch_v_m_from_volume_with_all_flavours(self):
"""This test case checks creation of instance from volume with all
types of flavor. For this test we need node with compute role:
8 VCPUs, 16+GB RAM and 160+GB disk for any compute
Steps:
1. Create bootable volume
1. Create a floating ip
2. Create an instance from an image with some flavor
3. Add the floating ip to the instance
4. Ping the instance by the floating ip
5. Delete the floating ip
6. delete the instance
7. Repeat all steps for all types of flavor
"""
image_id = [image.id for image in self.nova.images.list() if
image.name == 'TestVM'][0]
net = self.get_admin_int_net_id()
flavor_list = self.nova.flavors.list()
volume = common_functions.create_volume(self.cinder, image_id)
self.volumes.append(volume)
bdm = {'vda': volume.id}
for flavor in flavor_list:
floating_ip = self.nova.floating_ips.create()
self.floating_ips.append(floating_ip)
self.assertIn(floating_ip.ip, [fip_info.ip for fip_info in
self.nova.floating_ips.list()])
inst = common_functions.create_instance(self.nova,
"inst_543360_{}"
.format(flavor.name),
flavor.id, net,
[self.sec_group.id],
block_device_mapping=bdm,
inst_list=self.instances)
inst.add_floating_ip(floating_ip.ip)
self.assertTrue(common_functions.check_ip(self.nova, inst.id,
floating_ip.ip))
ping = common_functions.ping_command(floating_ip.ip)
common_functions.delete_instance(self.nova, inst.id)
self.assertTrue(ping, "Instance is not reachable")
def test_nova_launch_v_m_from_image_with_all_flavours(self):
"""This test case checks creation of instance from image with all
types of flavor. For this test we need node with compute role:
8 VCPUs, 16+GB RAM and 160+GB disk for any compute
Steps:
1. Create a floating ip
2. Create an instance from an image with some flavor
3. Add the floating ip to the instance
4. Ping the instance by the floating ip
5. Delete the floating ip
6. delete the instance
7. Repeat all steps for all types of flavor
"""
networks = self.neutron.list_networks()['networks']
net = [net['id'] for net in networks
if not net['router:external']][0]
image_id = [image.id for image in self.nova.images.list() if
image.name == 'TestVM'][0]
flavor_list = self.nova.flavors.list()
for flavor in flavor_list:
floating_ip = self.nova.floating_ips.create()
self.floating_ips.append(floating_ip)
self.assertIn(floating_ip.ip, [fip_info.ip for fip_info in
self.nova.floating_ips.list()])
inst = common_functions.create_instance(self.nova,
"inst_543358_{}"
.format(flavor.name),
flavor.id, net,
[self.sec_group.name],
image_id=image_id,
inst_list=self.instances)
inst.add_floating_ip(floating_ip.ip)
self.assertTrue(common_functions.check_ip(self.nova, inst.id,
floating_ip.ip))
ping = common_functions.ping_command(floating_ip.ip)
common_functions.delete_instance(self.nova, inst.id)
self.assertTrue(ping, "Instance is not reachable")
def test_live_migration_of_v_ms_with_data_on_root_and_ephemeral_disk(self):
"""This test checks Live Migration of VMs with data on root and
ephemeral disk
Steps:
1. Create flavor with ephemeral disk
2. Create a floating ip
3. Create an instance from an image with 'm1.ephemeral' flavor
4. Add the floating ip to the instance
5. Ssh to instance and create timestamp on root and ephemeral
disks
6. Ping the instance by the floating ip
7. Execute live migration
8. Check current hypervisor and status of instance
9. Check that packets loss was minimal
10. Ssh to instance and check timestamp on root and ephemeral
disks
"""
networks = self.neutron.list_networks()['networks']
net = [net['id'] for net in networks if not net['router:external']][0]
image_id = [image.id for image in self.nova.images.list() if
image.name == 'TestVM'][0]
flavor = self.nova.flavors.create("m1.ephemeral", 64, 1, 1,
ephemeral=1, is_public=True)
self.flavors.append(flavor)
floating_ip = self.nova.floating_ips.create()
self.floating_ips.append(floating_ip)
self.assertIn(floating_ip.ip, [fip_info.ip for fip_info in
self.nova.floating_ips.list()])
keys = self.nova.keypairs.create('key_2238776')
self.keys.append(keys)
private_key = paramiko.RSAKey.from_private_key(six.StringIO(str(
keys.private_key)))
inst = common_functions.create_instance(self.nova,
"inst_2238776_{}"
.format(flavor.name),
flavor.id, net,
[self.sec_group.name],
image_id=image_id,
key_name='key_2238776',
inst_list=self.instances)
inst.add_floating_ip(floating_ip.ip)
ping = common_functions.ping_command(floating_ip.ip, i=10)
self.assertTrue(ping, "Instance is not reachable")
out = []
with SSHClient(host=floating_ip.ip, username="cirros", password=None,
private_keys=[private_key]) as vm_r:
out.append(vm_r.execute("sudo sh -c 'date > /timestamp.txt'"))
out.append(vm_r.execute("sudo sh -c 'date > /mnt/timestamp.txt'"))
out.append(vm_r.execute("sudo -i cat /timestamp.txt"))
out.append(vm_r.execute("sudo -i cat /mnt/timestamp.txt"))
for i in out:
if i.get('stderr'):
raise Exception("ssh commands were executed with errors")
root_data = out[-2]['stdout'][0]
ephem_data = out[-1]['stdout'][0]
# live migration
hypervisors = {h.hypervisor_hostname: h for h in
self.nova.hypervisors.list()}
old_hyper = getattr(inst, "OS-EXT-SRV-ATTR:hypervisor_hostname")
new_hyper = [h for h in hypervisors.keys() if h != old_hyper][0]
ping = subprocess.Popen(["/bin/ping", "-c100", "-i1", floating_ip.ip],
stdout=subprocess.PIPE)
self.nova.servers.live_migrate(inst, new_hyper, block_migration=False,
disk_over_commit=False)
inst = self.nova.servers.get(inst.id)
timeout = 10
end_time = time() + 60 * timeout
while getattr(inst, "OS-EXT-SRV-ATTR:hypervisor_hostname") != \
new_hyper:
if time() > end_time:
msg = "Hypervisor is not changed after live migration"
raise AssertionError(msg)
sleep(1)
inst = self.nova.servers.get(inst.id)
self.assertEqual(inst.status, 'ACTIVE')
ping.wait()
output = ping.stdout.read().split('\n')[-3].split()
packets = {'transmitted': int(output[0]), 'received': int(output[3])}
loss = packets['transmitted'] - packets['received']
if loss > 5:
msg = "Packets loss exceeds the limit, {} packets were lost"
raise AssertionError(msg.format(loss))
out = []
with SSHClient(host=floating_ip.ip, username="cirros", password=None,
private_keys=[private_key]) as vm_r:
out.append(vm_r.execute("sudo -i cat /timestamp.txt"))
out.append(vm_r.execute("sudo -i cat /mnt/timestamp.txt"))
for i in out:
if i.get('stderr'):
raise Exception("ssh commands were executed with errors")
r_data = out[0]['stdout'][0]
ep_data = out[1]['stdout'][0]
self.assertEqual(root_data, r_data, "Data on root disk is changed")
self.assertEqual(ephem_data, ep_data, "Data on ephemeral disk is "
#.........这里部分代码省略.........
def test_live_migration_of_v_ms_with_data_on_root_and_ephemeral_disk(self):
"""This test checks Live Migration of VMs with data on root and
ephemeral disk
Steps:
1. Create flavor with ephemeral disk
2. Create a floating ip
3. Create an instance from an image with 'm1.ephemeral' flavor
4. Add the floating ip to the instance
5. Ssh to instance and create timestamp on root and ephemeral
disks
6. Ping the instance by the floating ip
7. Execute live migration
8. Check current hypervisor and status of instance
9. Check that packets loss was minimal
10. Ssh to instance and check timestamp on root and ephemeral
disks
"""
net = self.get_admin_int_net_id()
image_id = [image.id for image in self.nova.images.list() if
image.name == 'TestVM'][0]
flavor = self.nova.flavors.create("m1.ephemeral", 64, 1, 1,
ephemeral=1, is_public=True)
self.flavors.append(flavor)
floating_ip = self.nova.floating_ips.create()
self.floating_ips.append(floating_ip)
self.assertIn(floating_ip.ip, [fip_info.ip for fip_info in
self.nova.floating_ips.list()])
keys = self.nova.keypairs.create('key_2238776')
self.keys.append(keys)
private_key = paramiko.RSAKey.from_private_key(six.StringIO(str(
keys.private_key)))
inst = common_functions.create_instance(self.nova,
"inst_2238776_{}"
.format(flavor.name),
flavor.id, net,
[self.sec_group.id],
image_id=image_id,
key_name='key_2238776',
inst_list=self.instances)
self.instances.append(inst.id)
inst.add_floating_ip(floating_ip.ip)
ping = common_functions.ping_command(floating_ip.ip, i=10)
self.assertTrue(ping, "Instance is not reachable")
out = []
with SSHClient(host=floating_ip.ip, username="cirros", password=None,
private_keys=[private_key]) as vm_r:
out.append(vm_r.execute("sudo sh -c 'date > /timestamp.txt'"))
out.append(vm_r.execute("sudo sh -c 'date > /mnt/timestamp.txt'"))
out.append(vm_r.execute("sudo -i cat /timestamp.txt"))
out.append(vm_r.execute("sudo -i cat /mnt/timestamp.txt"))
for i in out:
if i.get('stderr'):
raise Exception("ssh commands were executed with errors")
root_data = out[-2]['stdout'][0]
ephem_data = out[-1]['stdout'][0]
self.live_migration(inst, floating_ip.ip)
out = []
with SSHClient(host=floating_ip.ip, username="cirros", password=None,
private_keys=[private_key]) as vm_r:
out.append(vm_r.execute("sudo -i cat /timestamp.txt"))
out.append(vm_r.execute("sudo -i cat /mnt/timestamp.txt"))
for i in out:
if i.get('stderr'):
raise Exception("ssh commands were executed with errors")
r_data = out[0]['stdout'][0]
ep_data = out[1]['stdout'][0]
self.assertEqual(root_data, r_data, "Data on root disk is changed")
self.assertEqual(ephem_data, ep_data, "Data on ephemeral disk is "
"changed")
请发表评论