summaryrefslogtreecommitdiff
path: root/tests/cloud_tests/collect.py
diff options
context:
space:
mode:
authorWesley Wiedenmeier <wesley.wiedenmeier@gmail.com>2016-12-22 17:27:37 -0500
committerScott Moser <smoser@brickies.net>2016-12-22 17:41:39 -0500
commitf53fc46aa732e3b29991b3e5e39da31a722945ee (patch)
treea301733aa9991b58b218f61b187240d275e44968 /tests/cloud_tests/collect.py
parentb2a9f33616c806ae6e052520a8589113308f567c (diff)
downloadvyos-cloud-init-f53fc46aa732e3b29991b3e5e39da31a722945ee.tar.gz
vyos-cloud-init-f53fc46aa732e3b29991b3e5e39da31a722945ee.zip
integration test: initial commit of integration test framework
The adds in end-to-end testing of cloud-init. The framework utilizes LXD and cloud images as a backend to test user-data passed in. Arbitrary data is then captured from predefined commands specified by the user. After collection, data verification is completed by running a series of Python unit tests against the collected data. Currently only the Ubuntu Trusty, Xenial, Yakkety, and Zesty releases are supported. Test cases for 50% of the modules is complete and available. Additionally a Read the Docs file was created to guide test writing and execution.
Diffstat (limited to 'tests/cloud_tests/collect.py')
-rw-r--r--tests/cloud_tests/collect.py161
1 files changed, 161 insertions, 0 deletions
diff --git a/tests/cloud_tests/collect.py b/tests/cloud_tests/collect.py
new file mode 100644
index 00000000..68b47d7a
--- /dev/null
+++ b/tests/cloud_tests/collect.py
@@ -0,0 +1,161 @@
+# This file is part of cloud-init. See LICENSE file for license information.
+
+from tests.cloud_tests import (config, LOG, setup_image, util)
+from tests.cloud_tests.stage import (PlatformComponent, run_stage, run_single)
+from tests.cloud_tests import (platforms, images, snapshots, instances)
+
+from functools import partial
+import os
+
+
+def collect_script(instance, base_dir, script, script_name):
+ """
+ collect script data
+ instance: instance to run script on
+ base_dir: base directory for output data
+ script: script contents
+ script_name: name of script to run
+ return_value: None, may raise errors
+ """
+ LOG.debug('running collect script: %s', script_name)
+ util.write_file(os.path.join(base_dir, script_name),
+ instance.run_script(script))
+
+
+def collect_test_data(args, snapshot, os_name, test_name):
+ """
+ collect data for test case
+ args: cmdline arguments
+ snapshot: instantiated snapshot
+ test_name: name or path of test to run
+ return_value: tuple of results and fail count
+ """
+ res = ({}, 1)
+
+ # load test config
+ test_name = config.path_to_name(test_name)
+ test_config = config.load_test_config(test_name)
+ user_data = test_config['cloud_config']
+ test_scripts = test_config['collect_scripts']
+ test_output_dir = os.sep.join(
+ (args.data_dir, snapshot.platform_name, os_name, test_name))
+ boot_timeout = (test_config.get('boot_timeout')
+ if isinstance(test_config.get('boot_timeout'), int) else
+ snapshot.config.get('timeout'))
+
+ # if test is not enabled, skip and return 0 failures
+ if not test_config.get('enabled', False):
+ LOG.warn('test config %s is not enabled, skipping', test_name)
+ return ({}, 0)
+
+ # create test instance
+ component = PlatformComponent(
+ partial(instances.get_instance, snapshot, user_data,
+ block=True, start=False, use_desc=test_name))
+
+ LOG.info('collecting test data for test: %s', test_name)
+ with component as instance:
+ start_call = partial(run_single, 'boot instance', partial(
+ instance.start, wait=True, wait_time=boot_timeout))
+ collect_calls = [partial(run_single, 'script {}'.format(script_name),
+ partial(collect_script, instance,
+ test_output_dir, script, script_name))
+ for script_name, script in test_scripts.items()]
+
+ res = run_stage('collect for test: {}'.format(test_name),
+ [start_call] + collect_calls)
+
+ return res
+
+
+def collect_snapshot(args, image, os_name):
+ """
+ collect data for snapshot of image
+ args: cmdline arguments
+ image: instantiated image with set up complete
+ return_value tuple of results and fail count
+ """
+ res = ({}, 1)
+
+ component = PlatformComponent(partial(snapshots.get_snapshot, image))
+
+ LOG.debug('creating snapshot for %s', os_name)
+ with component as snapshot:
+ LOG.info('collecting test data for os: %s', os_name)
+ res = run_stage(
+ 'collect test data for {}'.format(os_name),
+ [partial(collect_test_data, args, snapshot, os_name, test_name)
+ for test_name in args.test_config])
+
+ return res
+
+
+def collect_image(args, platform, os_name):
+ """
+ collect data for image
+ args: cmdline arguments
+ platform: instantiated platform
+ os_name: name of distro to collect for
+ return_value: tuple of results and fail count
+ """
+ res = ({}, 1)
+
+ os_config = config.load_os_config(os_name)
+ if not os_config.get('enabled'):
+ raise ValueError('OS {} not enabled'.format(os_name))
+
+ component = PlatformComponent(
+ partial(images.get_image, platform, os_config))
+
+ LOG.info('acquiring image for os: %s', os_name)
+ with component as image:
+ res = run_stage('set up and collect data for os: {}'.format(os_name),
+ [partial(setup_image.setup_image, args, image)] +
+ [partial(collect_snapshot, args, image, os_name)],
+ continue_after_error=False)
+
+ return res
+
+
+def collect_platform(args, platform_name):
+ """
+ collect data for platform
+ args: cmdline arguments
+ platform_name: platform to collect for
+ return_value: tuple of results and fail count
+ """
+ res = ({}, 1)
+
+ platform_config = config.load_platform_config(platform_name)
+ if not platform_config.get('enabled'):
+ raise ValueError('Platform {} not enabled'.format(platform_name))
+
+ component = PlatformComponent(
+ partial(platforms.get_platform, platform_name, platform_config))
+
+ LOG.info('setting up platform: %s', platform_name)
+ with component as platform:
+ res = run_stage('collect for platform: {}'.format(platform_name),
+ [partial(collect_image, args, platform, os_name)
+ for os_name in args.os_name])
+
+ return res
+
+
+def collect(args):
+ """
+ entry point for collection
+ args: cmdline arguments
+ return_value: fail count
+ """
+ (res, failed) = run_stage(
+ 'collect data', [partial(collect_platform, args, platform_name)
+ for platform_name in args.platform])
+
+ LOG.debug('collect stages: %s', res)
+ if args.result:
+ util.merge_results({'collect_stages': res}, args.result)
+
+ return failed
+
+# vi: ts=4 expandtab