Source code for cfme.fixtures.cli

import pytest

from collections import namedtuple
from contextlib import contextmanager
from six import iteritems

import cfme.utils.auth as authutil
from cfme.test_framework.sprout.client import SproutClient, SproutException
from cfme.utils.conf import cfme_data, credentials, auth_data
from cfme.utils.log import logger
from cfme.utils.version import get_stream
from cfme.utils.wait import wait_for

TimedCommand = namedtuple('TimedCommand', ['command', 'timeout'])

""" The Following fixtures are for provisioning one preconfigured or unconfigured appliance for
    testing from an FQDN provider unless there are no provisions available"""


@contextmanager
[docs]def fqdn_appliance(appliance, preconfigured, count): sp = SproutClient.from_config() available_providers = set(sp.call_method('available_providers')) required_providers = set(cfme_data['fqdn_providers']) usable_providers = available_providers & required_providers version = appliance.version.vstring stream = get_stream(appliance.version) for provider in usable_providers: try: apps, pool_id = sp.provision_appliances( count=count, preconfigured=preconfigured, version=version, stream=stream, provider=provider ) break except Exception as e: logger.warning("Couldn't provision appliance with following error:") logger.warning("{}".format(e)) continue else: logger.error("Couldn't provision an appliance at all") raise SproutException('No provision available') yield apps for app in apps: app.ssh_client.close() sp.destroy_pool(pool_id)
@pytest.fixture(scope='function')
[docs]def restore_hostname(appliance): """store and reset hostname""" orig_host = appliance.ssh_client.run_command('hostname') yield appliance.appliance_console_cli.set_hostname(orig_host)
@pytest.fixture()
[docs]def unconfigured_appliance(appliance): with fqdn_appliance(appliance, preconfigured=False, count=1) as apps: yield apps[0]
@pytest.fixture()
[docs]def unconfigured_appliance_secondary(appliance): with fqdn_appliance(appliance, preconfigured=False, count=1) as apps: yield apps[0]
@pytest.fixture()
[docs]def unconfigured_appliances(appliance): with fqdn_appliance(appliance, preconfigured=False, count=3) as apps: yield apps
@pytest.fixture()
[docs]def configured_appliance(appliance): with fqdn_appliance(appliance, preconfigured=True, count=1) as apps: yield apps[0]
@pytest.fixture(scope="function")
[docs]def dedicated_db_appliance(app_creds, unconfigured_appliance): """'ap' launch appliance_console, '' clear info screen, '5' setup db, '1' Creates v2_key, '1' selects internal db, '1' use partition, 'y' create dedicated db, 'pwd' db password, 'pwd' confirm db password + wait 360 secs and '' finish.""" app = unconfigured_appliance pwd = app_creds['password'] command_set = ('ap', '', '5', '1', '1', '1', 'y', pwd, TimedCommand(pwd, 360), '') app.appliance_console.run_commands(command_set) wait_for(lambda: app.db.is_dedicated_active) yield app
@pytest.fixture(scope="function")
[docs]def appliance_with_preset_time(temp_appliance_preconfig_funcscope): """Grabs fresh appliance and sets time and date prior to running tests""" temp_appliance_preconfig_funcscope.ssh_client.run_command( "appliance_console_cli --datetime 2020-10-20T09:58:00") return temp_appliance_preconfig_funcscope
@pytest.fixture()
[docs]def ipa_crud(): try: ipa_keys = [key for key, yaml in iteritems(auth_data.auth_providers) if yaml.type == authutil.FreeIPAAuthProvider.auth_type] ipa_provider = authutil.get_auth_crud(ipa_keys[0]) except AttributeError: pytest.skip('Unable to parse auth_data.yaml for freeipa server') except IndexError: pytest.skip('No freeipa server available for testing') logger.info('Configuring first available freeipa auth provider %s', ipa_provider) return ipa_provider
@pytest.fixture()
[docs]def app_creds(): return { 'username': credentials['database']['username'], 'password': credentials['database']['password'], 'sshlogin': credentials['ssh']['username'], 'sshpass': credentials['ssh']['password'] }
@pytest.fixture(scope="module")
[docs]def app_creds_modscope(): return { 'username': credentials['database']['username'], 'password': credentials['database']['password'], 'sshlogin': credentials['ssh']['username'], 'sshpass': credentials['ssh']['password'] }