| # Copyright 2016 Mirantis, Inc. |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); you may |
| # not use this file except in compliance with the License. You may obtain |
| # a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| # License for the specific language governing permissions and limitations |
| # under the License. |
| |
| from tcp_tests import settings_oslo |
| |
| |
| class EnvironmentManagerEmpty(object): |
| """Class-helper for creating VMs via devops environments""" |
| |
| _config = None |
| |
| def __init__(self, config=None): |
| """Initializing class instance and create the environment |
| |
| :param config: oslo.config object |
| :param config.hardware.conf_path: path to devops YAML template |
| :param config.hardware.current_snapshot: name of the snapshot that |
| descriebe environment status. |
| """ |
| self._config = config |
| |
| def lvm_storages(self): |
| """Returns data of lvm_storages on nodes in environment |
| |
| It's expected that data of self._config.lvm_storages will be |
| like this: |
| { |
| "node1": { |
| "device": "vdb" |
| }, |
| "node2": { |
| "device": "vdb" |
| }, |
| "node3": { |
| "device": "vdb" |
| }, |
| } |
| :rtype: dict |
| """ |
| return self._config.underlay.lvm |
| |
| def get_ssh_data(self, roles=None): |
| raise Exception("EnvironmentManagerEmpty doesn't have SSH details. " |
| "Please provide SSH details in config.underlay.ssh") |
| |
| def create_snapshot(self, name, description=None): |
| """Store environmetn state into the config object |
| |
| - Store the state of the environment <name> to the 'config' object |
| - Save 'config' object to a file 'config_<name>.ini' |
| """ |
| self._config.hardware.current_snapshot = name |
| settings_oslo.save_config(self._config, name) |
| |
| def revert_snapshot(self, name): |
| """Check the current state <name> of the environment |
| |
| - Check that the <name> matches the current state of the environment |
| that is stored in the 'self._config.hardware.current_snapshot' |
| - Try to reload 'config' object from a file 'config_<name>.ini' |
| If the file not found, then pass with defaults. |
| - Set <name> as the current state of the environment after reload |
| |
| :param name: string |
| """ |
| if self._config.hardware.current_snapshot != name: |
| raise Exception( |
| "EnvironmentManagerEmpty cannot revert nodes from {} to {}" |
| .format(self._config.hardware.current_snapshot, name)) |
| |
| def start(self): |
| """Start environment""" |
| pass |
| |
| def resume(self): |
| """Resume environment""" |
| pass |
| |
| def suspend(self): |
| """Suspend environment""" |
| pass |
| |
| def stop(self): |
| """Stop environment""" |
| pass |
| |
| def has_snapshot(self, name): |
| return self._config.hardware.current_snapshot == name |
| |
| def has_snapshot_config(self, name): |
| return self._config.hardware.current_snapshot == name |
| |
| def delete_environment(self): |
| """Delete environment""" |
| pass |