zuul/tests/remote/test_remote_action_modules.py

115 lines
3.9 KiB
Python

# Copyright 2018 Red Hat, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
import os
import textwrap
from tests.base import AnsibleZuulTestCase, FIXTURE_DIR
class TestActionModules(AnsibleZuulTestCase):
tenant_config_file = 'config/remote-action-modules/main.yaml'
def setUp(self):
super(TestActionModules, self).setUp()
self.fake_nodepool.remote_ansible = True
ansible_remote = os.environ.get('ZUUL_REMOTE_IPV4')
self.assertIsNotNone(ansible_remote)
# inject some files as forbidden sources
fixture_dir = os.path.join(FIXTURE_DIR, 'bwrap-mounts')
self.executor_server.execution_wrapper.bwrap_command.extend(
['--ro-bind', fixture_dir, '/opt'])
def _run_job(self, job_name, result):
# Keep the jobdir around so we can inspect contents if an
# assert fails. It will be cleaned up anyway as it is contained
# in a tmp dir which gets cleaned up after the test.
self.executor_server.keep_jobdir = True
# Output extra ansible info so we might see errors.
self.executor_server.verbose = True
conf = textwrap.dedent(
"""
- job:
name: {job_name}
run: playbooks/{job_name}.yaml
nodeset:
nodes:
- name: controller
label: whatever
- project:
check:
jobs:
- {job_name}
""".format(job_name=job_name))
file_dict = {'zuul.yaml': conf}
A = self.fake_gerrit.addFakeChange('org/project', 'master', 'A',
files=file_dict)
self.fake_gerrit.addEvent(A.getPatchsetCreatedEvent(1))
self.waitUntilSettled()
job = self.getJobFromHistory(job_name)
with self.jobLog(job):
build = self.history[-1]
self.assertEqual(build.result, result)
def test_assemble_module(self):
self._run_job('assemble-good', 'SUCCESS')
self._run_job('assemble-bad', 'FAILURE')
self._run_job('assemble-bad-symlink', 'FAILURE')
def test_copy_module(self):
self._run_job('copy-good', 'SUCCESS')
self._run_job('copy-bad', 'FAILURE')
self._run_job('copy-bad-symlink', 'FAILURE')
def test_includevars_module(self):
self._run_job('includevars-good', 'SUCCESS')
self._run_job('includevars-good-dir', 'SUCCESS')
self._run_job('includevars-bad', 'FAILURE')
self._run_job('includevars-bad-symlink', 'FAILURE')
self._run_job('includevars-bad-dir', 'FAILURE')
self._run_job('includevars-bad-dir-symlink', 'FAILURE')
def test_patch_module(self):
self._run_job('patch-good', 'SUCCESS')
self._run_job('patch-bad', 'FAILURE')
self._run_job('patch-bad-symlink', 'FAILURE')
def test_script_module(self):
self._run_job('script-good', 'SUCCESS')
self._run_job('script-bad', 'FAILURE')
self._run_job('script-bad-symlink', 'FAILURE')
def test_template_module(self):
self._run_job('template-good', 'SUCCESS')
self._run_job('template-bad', 'FAILURE')
self._run_job('template-bad-symlink', 'FAILURE')
def test_unarchive_module(self):
self._run_job('unarchive-good', 'SUCCESS')
self._run_job('unarchive-bad', 'FAILURE')
self._run_job('unarchive-bad-symlink', 'FAILURE')