summaryrefslogtreecommitdiff
path: root/tests/cloud_tests/snapshots/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/snapshots/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/snapshots/base.py')
-rw-r--r--tests/cloud_tests/snapshots/base.py44
1 files changed, 44 insertions, 0 deletions
diff --git a/tests/cloud_tests/snapshots/base.py b/tests/cloud_tests/snapshots/base.py
new file mode 100644
index 00000000..d715f037
--- /dev/null
+++ b/tests/cloud_tests/snapshots/base.py
@@ -0,0 +1,44 @@
+# This file is part of cloud-init. See LICENSE file for license information.
+
+
+class Snapshot(object):
+ """
+ Base class for snapshots
+ """
+ platform_name = None
+
+ def __init__(self, properties, config):
+ """
+ Set up snapshot
+ """
+ self.properties = properties
+ self.config = config
+
+ def __str__(self):
+ """
+ a brief description of the snapshot
+ """
+ return '-'.join((self.properties['os'], self.properties['release']))
+
+ def launch(self, user_data, meta_data=None, block=True, start=True,
+ use_desc=None):
+ """
+ launch instance
+
+ user_data: user-data for the instance
+ instance_id: instance-id for the instance
+ block: wait until instance is created
+ start: start instance and wait until fully started
+ use_desc: description of snapshot instance use
+
+ return_value: an Instance
+ """
+ raise NotImplementedError
+
+ def destroy(self):
+ """
+ Clean up snapshot data
+ """
+ pass
+
+# vi: ts=4 expandtab