summaryrefslogtreecommitdiff
path: root/tests/cloud_tests/platforms/base.py
diff options
context:
space:
mode:
authorScott Moser <smoser@brickies.net>2017-01-20 10:06:55 -0500
committerScott Moser <smoser@brickies.net>2017-01-20 10:06:55 -0500
commitd00b7dba8767618ae360f56bf64b7ab7a8c49d2e (patch)
tree349799f76c39669a03a6acbd48502970c0abb994 /tests/cloud_tests/platforms/base.py
parentfa3009b64949fef3744ddb940f01477dfa2d25e5 (diff)
parent7fb6f78177b5ece10ca7c54ba3958010a9987f06 (diff)
downloadvyos-cloud-init-d00b7dba8767618ae360f56bf64b7ab7a8c49d2e.tar.gz
vyos-cloud-init-d00b7dba8767618ae360f56bf64b7ab7a8c49d2e.zip
merge from 0.7.9 at 0.7.9
Diffstat (limited to 'tests/cloud_tests/platforms/base.py')
-rw-r--r--tests/cloud_tests/platforms/base.py53
1 files changed, 53 insertions, 0 deletions
diff --git a/tests/cloud_tests/platforms/base.py b/tests/cloud_tests/platforms/base.py
new file mode 100644
index 00000000..615e2e06
--- /dev/null
+++ b/tests/cloud_tests/platforms/base.py
@@ -0,0 +1,53 @@
+# This file is part of cloud-init. See LICENSE file for license information.
+
+
+class Platform(object):
+ """
+ Base class for platforms
+ """
+ platform_name = None
+
+ def __init__(self, config):
+ """
+ Set up platform
+ """
+ self.config = config
+
+ def get_image(self, img_conf):
+ """
+ Get image using 'img_conf', where img_conf is a dict containing all
+ image configuration parameters
+
+ in this dict there must be a 'platform_ident' key containing
+ configuration for identifying each image on a per platform basis
+
+ see implementations for get_image() for details about the contents
+ of the platform's config entry
+
+ note: see 'releases' main_config.yaml for example entries
+
+ img_conf: configuration for image
+ return_value: cloud_tests.images instance
+ """
+ raise NotImplementedError
+
+ def destroy(self):
+ """
+ Clean up platform data
+ """
+ pass
+
+ def _extract_img_platform_config(self, img_conf):
+ """
+ extract platform configuration for current platform from img_conf
+ """
+ platform_ident = img_conf.get('platform_ident')
+ if not platform_ident:
+ raise ValueError('invalid img_conf, missing \'platform_ident\'')
+ ident = platform_ident.get(self.platform_name)
+ if not ident:
+ raise ValueError('img_conf: {} missing config for platform {}'
+ .format(img_conf, self.platform_name))
+ return ident
+
+# vi: ts=4 expandtab