blob: 0e8cbeda17148647b04fe0d6564e2badc156e45a [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')
Dennis Dmitrievee5ef232018-08-31 13:53:18 +030025def drivetrain_actions(config, underlay_actions, salt_actions):
sgudzb67ce732018-02-13 17:58:31 +020026 """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 """
Dennis Dmitrievee5ef232018-08-31 13:53:18 +030032 return drivetrain_manager.DrivetrainManager(config, underlay_actions,
33 salt_actions)
sgudzb67ce732018-02-13 17:58:31 +020034
35
36@pytest.mark.revert_snapshot(ext.SNAPSHOT.drivetrain_deployed)
37@pytest.fixture(scope='function')
38def drivetrain_deployed(revert_snapshot, request, config,
39 hardware, underlay, salt_deployed,
40 drivetrain_actions):
41 """Fixture to get or install Drivetrain on the environment
42
43 :param revert_snapshot: fixture that reverts snapshot that is specified
44 in test with @pytest.mark.revert_snapshot(<name>)
45 :param request: fixture provides pytest data
46 :param config: fixture provides oslo.config
47 :param hardware: fixture provides enviromnet manager
48 :param underlay: fixture provides underlay manager
49 :param drivetrain_actions: fixture provides OSSManager instance
50 :rtype: DrivetrainManager
51
52 If config.drivetrain.drivetrain_installed is not set, this
53 fixture assumes that the Drivetrain were not installed
54 , and do the following:
55 - install Drivetrain
56 - make snapshot with name 'drivetrain_deployed'
57 - return DrivetrainManager
58
59 If config.drivetrain.drivetrain_installed was set, this fixture
60 assumes that the Drivetrain were already installed, and do
61 the following:
62 - return DrivetrainManager instance
63
64 If you want to revert 'drivetrain_deployed' snapshot, please use mark:
65 @pytest.mark.revert_snapshot("drivetrain_deployed")
66 """
67 if not config.drivetrain.drivetrain_installed:
68 steps_path = config.drivetrain_deploy.drivetrain_steps_path
69 commands = underlay.read_template(steps_path)
70 drivetrain_actions.install(commands)
71 hardware.create_snapshot(ext.SNAPSHOT.drivetrain_deployed)
72 salt_deployed.sync_time()
73
74 else:
75 # 1. hardware environment created and powered on
76 # 2. config.underlay.ssh contains SSH access to provisioned nodes
77 # (can be passed from external config with TESTS_CONFIGS variable)
78 # 3. config.tcp.* options contain access credentials to the already
79 # installed TCP API endpoint
80 pass
81
82 return drivetrain_actions