2019-03-05 07:30:24 +01:00
|
|
|
"""Hetzner Cloud plugin for integration tests."""
|
2019-07-12 08:46:20 +02:00
|
|
|
from __future__ import (absolute_import, division, print_function)
|
|
|
|
__metaclass__ = type
|
2019-03-05 07:30:24 +01:00
|
|
|
|
2019-04-09 22:29:30 +02:00
|
|
|
import os
|
|
|
|
|
2019-08-06 23:43:29 +02:00
|
|
|
from ..util import (
|
2019-04-09 22:29:30 +02:00
|
|
|
display,
|
|
|
|
is_shippable,
|
|
|
|
ConfigParser,
|
|
|
|
)
|
2019-03-05 07:30:24 +01:00
|
|
|
|
2019-08-06 23:43:29 +02:00
|
|
|
from . import (
|
2019-03-05 07:30:24 +01:00
|
|
|
CloudProvider,
|
|
|
|
CloudEnvironment,
|
|
|
|
CloudEnvironmentConfig,
|
|
|
|
)
|
|
|
|
|
2019-08-06 23:43:29 +02:00
|
|
|
from ..core_ci import (
|
2019-04-09 22:29:30 +02:00
|
|
|
AnsibleCoreCI,
|
|
|
|
)
|
2019-03-05 07:30:24 +01:00
|
|
|
|
|
|
|
|
|
|
|
class HcloudCloudProvider(CloudProvider):
|
|
|
|
"""Hetzner Cloud provider plugin. Sets up cloud resources before
|
|
|
|
delegation.
|
|
|
|
"""
|
|
|
|
|
|
|
|
def __init__(self, args):
|
|
|
|
"""
|
|
|
|
:type args: TestConfig
|
|
|
|
"""
|
|
|
|
super(HcloudCloudProvider, self).__init__(args)
|
|
|
|
|
|
|
|
def filter(self, targets, exclude):
|
|
|
|
"""Filter out the cloud tests when the necessary config and resources are not available.
|
|
|
|
:type targets: tuple[TestTarget]
|
|
|
|
:type exclude: list[str]
|
|
|
|
"""
|
2019-04-09 22:29:30 +02:00
|
|
|
if os.path.isfile(self.config_static_path):
|
|
|
|
return
|
|
|
|
|
|
|
|
aci = self._create_ansible_core_ci()
|
|
|
|
|
|
|
|
if os.path.isfile(aci.ci_key):
|
|
|
|
return
|
|
|
|
|
|
|
|
if is_shippable():
|
2019-03-05 07:30:24 +01:00
|
|
|
return
|
|
|
|
|
|
|
|
super(HcloudCloudProvider, self).filter(targets, exclude)
|
|
|
|
|
|
|
|
def setup(self):
|
|
|
|
"""Setup the cloud resource before delegation and register a cleanup callback."""
|
|
|
|
super(HcloudCloudProvider, self).setup()
|
|
|
|
|
2019-04-09 22:29:30 +02:00
|
|
|
if not self._use_static_config():
|
|
|
|
self._setup_dynamic()
|
|
|
|
|
|
|
|
def _setup_dynamic(self):
|
|
|
|
"""Request Hetzner credentials through the Ansible Core CI service."""
|
|
|
|
display.info('Provisioning %s cloud environment.' % self.platform, verbosity=1)
|
|
|
|
|
|
|
|
config = self._read_config_template()
|
2019-03-05 07:30:24 +01:00
|
|
|
|
2019-04-09 22:29:30 +02:00
|
|
|
aci = self._create_ansible_core_ci()
|
|
|
|
|
|
|
|
response = aci.start()
|
|
|
|
|
|
|
|
if not self.args.explain:
|
|
|
|
token = response['hetzner']['token']
|
|
|
|
|
|
|
|
display.sensitive.add(token)
|
|
|
|
display.info('Hetzner Cloud Token: %s' % token, verbosity=1)
|
|
|
|
|
|
|
|
values = dict(
|
|
|
|
TOKEN=token,
|
|
|
|
)
|
|
|
|
|
2019-09-17 06:01:37 +02:00
|
|
|
display.sensitive.add(values['TOKEN'])
|
|
|
|
|
2019-04-09 22:29:30 +02:00
|
|
|
config = self._populate_config_template(config, values)
|
|
|
|
|
|
|
|
self._write_config(config)
|
|
|
|
|
|
|
|
def _create_ansible_core_ci(self):
|
|
|
|
"""
|
|
|
|
:rtype: AnsibleCoreCI
|
|
|
|
"""
|
|
|
|
return AnsibleCoreCI(self.args, 'hetzner', 'hetzner', persist=False, stage=self.args.remote_stage, provider=self.args.remote_provider)
|
2019-03-05 07:30:24 +01:00
|
|
|
|
|
|
|
|
|
|
|
class HcloudCloudEnvironment(CloudEnvironment):
|
|
|
|
"""Hetzner Cloud cloud environment plugin. Updates integration test environment
|
|
|
|
after delegation.
|
|
|
|
"""
|
|
|
|
|
|
|
|
def get_environment_config(self):
|
2019-07-13 06:58:19 +02:00
|
|
|
"""
|
|
|
|
:rtype: CloudEnvironmentConfig
|
|
|
|
"""
|
2019-03-05 07:30:24 +01:00
|
|
|
parser = ConfigParser()
|
|
|
|
parser.read(self.config_path)
|
|
|
|
|
|
|
|
env_vars = dict(
|
|
|
|
HCLOUD_TOKEN=parser.get('default', 'hcloud_api_token'),
|
|
|
|
)
|
|
|
|
|
2019-09-17 06:01:37 +02:00
|
|
|
display.sensitive.add(env_vars['HCLOUD_TOKEN'])
|
|
|
|
|
2019-03-05 07:30:24 +01:00
|
|
|
ansible_vars = dict(
|
|
|
|
hcloud_prefix=self.resource_prefix,
|
|
|
|
)
|
|
|
|
|
|
|
|
ansible_vars.update(dict((key.lower(), value) for key, value in env_vars.items()))
|
|
|
|
|
|
|
|
return CloudEnvironmentConfig(
|
|
|
|
env_vars=env_vars,
|
|
|
|
ansible_vars=ansible_vars,
|
|
|
|
)
|