blob: e0e709bbefb7222324d40f46025eedf5973811eb [file] [log] [blame]
sgudzb67ce732018-02-13 17:58:31 +02001# Copyright 2016 Mirantis, Inc.
2#
3# Licensed under the Apache License, Version 2.0 (the "License"); you may
4# not use this file except in compliance with the License. You may obtain
5# a copy of the License at
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12# License for the specific language governing permissions and limitations
13# under the License.
14
15import pytest
16
17from tcp_tests import logger
18from tcp_tests.helpers import ext
19from tcp_tests.managers import drivetrain_manager
20
21LOG = logger.logger
22
23
24@pytest.fixture(scope='function')
25def drivetrain_actions(config, underlay, salt_actions):
26 """Fixture that provides various actions for Drivetrain
27
28 :param config: fixture provides oslo.config
29 :param underlay: fixture provides underlay manager
30 :rtype: DrivetrainManager
31 """
32 return drivetrain_manager.DrivetrainManager(config, underlay, salt_actions)
33
34
35@pytest.mark.revert_snapshot(ext.SNAPSHOT.drivetrain_deployed)
36@pytest.fixture(scope='function')
37def drivetrain_deployed(revert_snapshot, request, config,
38 hardware, underlay, salt_deployed,
39 drivetrain_actions):
40 """Fixture to get or install Drivetrain on the environment
41
42 :param revert_snapshot: fixture that reverts snapshot that is specified
43 in test with @pytest.mark.revert_snapshot(<name>)
44 :param request: fixture provides pytest data
45 :param config: fixture provides oslo.config
46 :param hardware: fixture provides enviromnet manager
47 :param underlay: fixture provides underlay manager
48 :param drivetrain_actions: fixture provides OSSManager instance
49 :rtype: DrivetrainManager
50
51 If config.drivetrain.drivetrain_installed is not set, this
52 fixture assumes that the Drivetrain were not installed
53 , and do the following:
54 - install Drivetrain
55 - make snapshot with name 'drivetrain_deployed'
56 - return DrivetrainManager
57
58 If config.drivetrain.drivetrain_installed was set, this fixture
59 assumes that the Drivetrain were already installed, and do
60 the following:
61 - return DrivetrainManager instance
62
63 If you want to revert 'drivetrain_deployed' snapshot, please use mark:
64 @pytest.mark.revert_snapshot("drivetrain_deployed")
65 """
66 if not config.drivetrain.drivetrain_installed:
67 steps_path = config.drivetrain_deploy.drivetrain_steps_path
68 commands = underlay.read_template(steps_path)
69 drivetrain_actions.install(commands)
70 hardware.create_snapshot(ext.SNAPSHOT.drivetrain_deployed)
71 salt_deployed.sync_time()
72
73 else:
74 # 1. hardware environment created and powered on
75 # 2. config.underlay.ssh contains SSH access to provisioned nodes
76 # (can be passed from external config with TESTS_CONFIGS variable)
77 # 3. config.tcp.* options contain access credentials to the already
78 # installed TCP API endpoint
79 pass
80
81 return drivetrain_actions