ca405ae55f05d921da65d287adb5733a34f92086
[functest.git] / functest / opnfv_tests / openstack / shaker / shaker.py
1 #!/usr/bin/env python
2
3 # Copyright (c) 2018 Orange and others.
4 #
5 # All rights reserved. This program and the accompanying materials
6 # are made available under the terms of the Apache License, Version 2.0
7 # which accompanies this distribution, and is available at
8 # http://www.apache.org/licenses/LICENSE-2.0
9
10 """
11 Shaker_ wraps around popular system network testing tools like iperf, iperf3
12 and netperf (with help of flent). Shaker is able to deploy OpenStack instances
13 and networks in different topologies. Shaker scenario specifies the deployment
14 and list of tests to execute.
15
16 .. _Shaker: http://pyshaker.readthedocs.io/en/latest/
17 """
18
19 import logging
20 import os
21
22 import scp
23
24 from functest.core import singlevm
25
26
27 class Shaker(singlevm.SingleVm2):
28     """Run shaker full+perf l2 and l3"""
29     # pylint: disable=too-many-instance-attributes
30
31     __logger = logging.getLogger(__name__)
32
33     filename = '/home/opnfv/functest/images/shaker-image.qcow2'
34     flavor_ram = 512
35     flavor_vcpus = 1
36     flavor_disk = 3
37     username = 'ubuntu'
38     port = 9000
39     ssh_connect_loops = 12
40
41     def prepare(self):
42         super(Shaker, self).prepare()
43         self.cloud.create_security_group_rule(
44             self.sec.id, port_range_min=self.port, port_range_max=self.port,
45             protocol='tcp', direction='ingress')
46
47     def execute(self):
48         """
49         Returns:
50             - 0 if success
51             - 1 on operation error
52         """
53         assert self.ssh
54         keystone_id = self.orig_cloud.search_services('keystone')[0].id
55         self.__logger.debug("keystone id: %s", keystone_id)
56         endpoint = self.orig_cloud.search_endpoints(
57             filters={'interface': 'public',
58                      'service_id': keystone_id})[0].url
59         self.__logger.debug("keystone endpoint: %s", endpoint)
60         self.orig_cloud.grant_role(
61             "admin", user=self.project.user.id,
62             project=self.project.project.id,
63             domain=self.project.domain.id)
64         self.orig_cloud.grant_role(
65             "heat_stack_owner", user=self.project.user.id,
66             project=self.project.project.id,
67             domain=self.project.domain.id)
68         scpc = scp.SCPClient(self.ssh.get_transport())
69         scpc.put('/home/opnfv/functest/conf/env_file', remote_path='~/')
70         if os.environ.get('OS_CACERT'):
71             scpc.put(os.environ.get('OS_CACERT'), remote_path='~/os_cacert')
72         (_, stdout, stderr) = self.ssh.exec_command(
73             'source ~/env_file && '
74             'export OS_INTERFACE=public && '
75             'export OS_AUTH_URL={} && '
76             'export OS_USERNAME={} && '
77             'export OS_PROJECT_NAME={} && '
78             'export OS_PASSWORD={} && '
79             '{}'
80             'env && '
81             'shaker --image-name {} --flavor-name {} '
82             '--server-endpoint {}:9000 --scenario '
83             'openstack/full_l2,'
84             'openstack/full_l3_east_west,'
85             'openstack/full_l3_north_south,'
86             'openstack/perf_l3_north_south '
87             '--report report.html --output report.json'.format(
88                 endpoint, self.project.user.name, self.project.project.name,
89                 self.project.password,
90                 'export OS_CACERT=~/os_cacert && ' if os.environ.get(
91                     'OS_CACERT') else '',
92                 self.image.name, self.flavor.name,
93                 self.fip.floating_ip_address))
94         self.__logger.info("output:\n%s", stdout.read())
95         self.__logger.info("error:\n%s", stderr.read())
96         if not os.path.exists(self.res_dir):
97             os.makedirs(self.res_dir)
98         try:
99             scpc.get('report.json', self.res_dir)
100             scpc.get('report.html', self.res_dir)
101         except scp.SCPException:
102             self.__logger.exception("cannot get report files")
103             return 1
104         return stdout.channel.recv_exit_status()