Common Dockerfile for CVP-Sanity and CVP-SPT
Related-Task: #PROD-26312(PROD:26312)
Change-Id: I457a8d5c6ff73d944518f6b0c2c568f8286728a9
diff --git a/test_set/cvp_spt/tests/test_vm2vm.py b/test_set/cvp_spt/tests/test_vm2vm.py
new file mode 100644
index 0000000..9e1d5d7
--- /dev/null
+++ b/test_set/cvp_spt/tests/test_vm2vm.py
@@ -0,0 +1,103 @@
+import os
+import random
+import time
+import pytest
+from cvp_spt import utils
+from cvp_spt.utils import os_client
+from cvp_spt.utils import ssh
+
+
+def test_vm2vm (openstack_clients, pair, os_resources, record_property):
+ os_actions = os_client.OSCliActions(openstack_clients)
+ config = utils.get_configuration()
+ timeout = int(config.get('nova_timeout', 30))
+ try:
+ zone1 = [service.zone for service in openstack_clients.compute.services.list() if service.host == pair[0]]
+ zone2 = [service.zone for service in openstack_clients.compute.services.list() if service.host == pair[1]]
+ vm1 = os_actions.create_basic_server(os_resources['image_id'],
+ os_resources['flavor_id'],
+ os_resources['net1'],
+ '{0}:{1}'.format(zone1[0],pair[0]),
+ [os_resources['sec_group'].name],
+ os_resources['keypair'].name)
+
+ vm2 = os_actions.create_basic_server(os_resources['image_id'],
+ os_resources['flavor_id'],
+ os_resources['net1'],
+ '{0}:{1}'.format(zone1[0],pair[0]),
+ [os_resources['sec_group'].name],
+ os_resources['keypair'].name)
+
+ vm3 = os_actions.create_basic_server(os_resources['image_id'],
+ os_resources['flavor_id'],
+ os_resources['net1'],
+ '{0}:{1}'.format(zone2[0],pair[1]),
+ [os_resources['sec_group'].name],
+ os_resources['keypair'].name)
+
+ vm4 = os_actions.create_basic_server(os_resources['image_id'],
+ os_resources['flavor_id'],
+ os_resources['net2'],
+ '{0}:{1}'.format(zone2[0],pair[1]),
+ [os_resources['sec_group'].name],
+ os_resources['keypair'].name)
+
+ vm_info = []
+ vms = []
+ vms.extend([vm1,vm2,vm3,vm4])
+ fips = []
+ time.sleep(5)
+ for i in range(4):
+ fip = openstack_clients.compute.floating_ips.create(os_resources['ext_net']['name'])
+ fips.append(fip.id)
+ status = openstack_clients.compute.servers.get(vms[i]).status
+ if status != 'ACTIVE':
+ print "VM #{0} {1} is not ready. Status {2}".format(i,vms[i].id,status)
+ time.sleep(timeout)
+ status = openstack_clients.compute.servers.get(vms[i]).status
+ if status != 'ACTIVE':
+ raise Exception('VM is not ready')
+ vms[i].add_floating_ip(fip)
+ private_address = vms[i].addresses[vms[i].addresses.keys()[0]][0]['addr']
+ time.sleep(5)
+ try:
+ ssh.prepare_iperf(fip.ip,private_key=os_resources['keypair'].private_key)
+ except Exception as e:
+ print e
+ print "ssh.prepare_iperf was not successful, retry after {} sec".format(timeout)
+ time.sleep(timeout)
+ ssh.prepare_iperf(fip.ip,private_key=os_resources['keypair'].private_key)
+ vm_info.append({'vm': vms[i], 'fip': fip.ip, 'private_address': private_address})
+
+ transport1 = ssh.SSHTransport(vm_info[0]['fip'], 'ubuntu', password='dd', private_key=os_resources['keypair'].private_key)
+
+ result1 = transport1.exec_command('iperf -c {} | tail -n 1'.format(vm_info[1]['private_address']))
+ print ' '.join(result1.split()[-2::])
+ record_property("same {0}-{1}".format(zone1[0],zone2[0]), ' '.join(result1.split()[-2::]))
+ result2 = transport1.exec_command('iperf -c {} | tail -n 1'.format(vm_info[2]['private_address']))
+ print ' '.join(result2.split()[-2::])
+ record_property("diff host {0}-{1}".format(zone1[0],zone2[0]), ' '.join(result2.split()[-2::]))
+ result3 = transport1.exec_command('iperf -c {} -P 10 | tail -n 1'.format(vm_info[2]['private_address']))
+ print ' '.join(result3.split()[-2::])
+ record_property("dif host 10 threads {0}-{1}".format(zone1[0],zone2[0]), ' '.join(result3.split()[-2::]))
+ result4 = transport1.exec_command('iperf -c {} | tail -n 1'.format(vm_info[2]['fip']))
+ print ' '.join(result4.split()[-2::])
+ record_property("diff host fip {0}-{1}".format(zone1[0],zone2[0]), ' '.join(result4.split()[-2::]))
+ result5 = transport1.exec_command('iperf -c {} | tail -n 1'.format(vm_info[3]['private_address']))
+ print ' '.join(result5.split()[-2::])
+ record_property("diff host, diff net {0}-{1}".format(zone1[0],zone2[0]), ' '.join(result5.split()[-2::]))
+
+ print "Remove VMs"
+ for vm in vms:
+ openstack_clients.compute.servers.delete(vm)
+ print "Remove FIPs"
+ for fip in fips:
+ openstack_clients.compute.floating_ips.delete(fip)
+ except Exception as e:
+ print e
+ print "Something went wrong"
+ for vm in vms:
+ openstack_clients.compute.servers.delete(vm)
+ for fip in fips:
+ openstack_clients.compute.floating_ips.delete(fip)
+ pytest.fail("Something went wrong")