Rewrite refstack testcase
[functest.git] / functest / opnfv_tests / openstack / refstack / refstack.py
1 #!/usr/bin/env python
2
3 # Copyright (c) 2017 Huawei Technologies Co.,Ltd 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 """Refstack testcase implementation."""
11
12 import logging
13 import os
14 import shutil
15 import time
16
17 from refstack_client import list_parser
18 from xtesting.core import testcase
19 from xtesting.energy import energy
20
21 from functest.opnfv_tests.openstack.snaps import snaps_utils
22 from functest.opnfv_tests.openstack.tempest import conf_utils
23 from functest.opnfv_tests.openstack.tempest import tempest
24 from functest.utils import config
25
26
27 class Refstack(tempest.TempestCommon):
28     """Refstack testcase implementation class."""
29
30     __logger = logging.getLogger(__name__)
31
32     defcorelist = os.path.join(
33         getattr(config.CONF, 'dir_refstack_data'), 'defcore.txt')
34
35     def __init__(self, **kwargs):
36         if "case_name" not in kwargs:
37             kwargs["case_name"] = 'refstack'
38         super(Refstack, self).__init__(**kwargs)
39         self.res_dir = os.path.join(
40             getattr(config.CONF, 'dir_results'), 'refstack')
41         self.list = os.path.join(self.res_dir, 'tempest-list.txt')
42
43     @energy.enable_recording
44     def run(self, **kwargs):
45         """Start Refstack testcase."""
46         self.start_time = time.time()
47         try:
48             if not os.path.exists(self.res_dir):
49                 os.makedirs(self.res_dir)
50             resources = self.resources.create()
51             compute_cnt = snaps_utils.get_active_compute_cnt(
52                 self.resources.os_creds)
53             conf_file = conf_utils.configure_verifier(self.deployment_dir)
54             conf_utils.configure_tempest_update_params(
55                 conf_file, self.res_dir,
56                 network_name=resources.get("network_name"),
57                 image_id=resources.get("image_id"),
58                 flavor_id=resources.get("flavor_id"),
59                 compute_cnt=compute_cnt)
60             parser = list_parser.TestListParser('/src/tempest')
61             nfile = parser.get_normalized_test_list(Refstack.defcorelist)
62             shutil.copyfile(nfile, self.list)
63             self.run_verifier_tests()
64             self.parse_verifier_result()
65             self.generate_report()
66             res = testcase.TestCase.EX_OK
67         except Exception as err:  # pylint: disable=broad-except
68             self.__logger.error('Error with run: %s', err)
69             res = testcase.TestCase.EX_RUN_ERROR
70         finally:
71             self.resources.cleanup()
72         self.stop_time = time.time()
73         return res