Initial OSA zuul v3 role jobs

This patch implements an initial set of jobs intended to match
the current job execution method. It does not intend to improve
how the jobs are executed - only to replicate what is currently
in openstack-infra/openstack-zuul-jobs and provide the platform
to iterate on.

Change-Id: If86f31a6ff188c57c5981dcf9eddc26af7101b25
This commit is contained in:
Jesse Pretorius 2017-10-17 17:43:32 +01:00
parent d9d5a1cef9
commit ed224c54a6
6 changed files with 130 additions and 21 deletions

View File

@ -69,7 +69,9 @@ target_name = 'openstack-ansible-' + role_name
title = 'OpenStack-Ansible Documentation: ' + role_name + 'role' title = 'OpenStack-Ansible Documentation: ' + role_name + 'role'
# The link to the browsable source code (for the left hand menu) # The link to the browsable source code (for the left hand menu)
oslosphinx_cgit_link = 'https://git.openstack.org/cgit/openstack/' + target_name oslosphinx_cgit_link = (
"https://git.openstack.org/cgit/openstack/{}".format(target_name)
)
# The version info for the project you're documenting, acts as replacement for # The version info for the project you're documenting, acts as replacement for
# |version| and |release|, also used in various other places throughout the # |version| and |release|, also used in various other places throughout the

View File

@ -65,7 +65,9 @@ target_name = 'openstack-ansible-' + role_name
title = 'OpenStack-Ansible Release Notes: ' + role_name + 'role' title = 'OpenStack-Ansible Release Notes: ' + role_name + 'role'
# The link to the browsable source code (for the left hand menu) # The link to the browsable source code (for the left hand menu)
oslosphinx_cgit_link = 'https://git.openstack.org/cgit/openstack/' + target_name oslosphinx_cgit_link = (
"https://git.openstack.org/cgit/openstack/{}".format(target_name)
)
# The version info for the project you're documenting, acts as replacement for # The version info for the project you're documenting, acts as replacement for
# |version| and |release|, also used in various other places throughout the # |version| and |release|, also used in various other places throughout the

View File

@ -49,24 +49,12 @@ install_pkg_deps() {
eval sudo $pkg_mgr_cmd $pkg_deps eval sudo $pkg_mgr_cmd $pkg_deps
} }
git_clone_repo() { # Install the host distro package dependencies
if [[ ! -d tests/common ]]; then
# The tests repo doesn't need a clone, we can just
# symlink it.
if [[ "$(basename ${WORKING_DIR})" == "openstack-ansible-tests" ]]; then
ln -s ${WORKING_DIR} ${WORKING_DIR}/tests/common
else
git clone \
https://git.openstack.org/openstack/openstack-ansible-tests \
tests/common
fi
fi
}
install_pkg_deps install_pkg_deps
git_clone_repo # Clone the tests repo for access to the common test script
source tests/tests-repo-clone.sh
# start executing the main test script # Execute the common test script
source tests/common/run_tests_common.sh source tests/common/run_tests_common.sh

View File

@ -33,6 +33,7 @@ set -e
export TESTING_HOME=${TESTING_HOME:-$HOME} export TESTING_HOME=${TESTING_HOME:-$HOME}
export WORKING_DIR=${WORKING_DIR:-$(pwd)} export WORKING_DIR=${WORKING_DIR:-$(pwd)}
export CLONE_UPGRADE_TESTS=${CLONE_UPGRADE_TESTS:-no} export CLONE_UPGRADE_TESTS=${CLONE_UPGRADE_TESTS:-no}
export ZUUL_TESTS_CLONE_LOCATION="/home/zuul/src/git.openstack.org/openstack/openstack-ansible-tests"
## Functions ----------------------------------------------------------------- ## Functions -----------------------------------------------------------------
@ -52,7 +53,11 @@ EOF
# If zuul-cloner is present, use it so that we # If zuul-cloner is present, use it so that we
# also include any dependent patches from the # also include any dependent patches from the
# tests repo noted in the commit message. # tests repo noted in the commit message.
if [[ -x /usr/zuul-env/bin/zuul-cloner ]]; then # We only want to use zuul-cloner if we detect
# zuul v2 running, so we check for the presence
# of the ZUUL_REF environment variable.
# ref: http://git.openstack.org/cgit/openstack-infra/zuul/tree/zuul/ansible/filter/zuul_filters.py?h=feature/zuulv3#n17
if [[ -x /usr/zuul-env/bin/zuul-cloner ]] && [[ "${ZUUL_REF:-none}" != "none" ]]; then
# Prepare the clonemap for zuul-cloner to use # Prepare the clonemap for zuul-cloner to use
create_tests_clonemap create_tests_clonemap
@ -74,9 +79,22 @@ if [[ -x /usr/zuul-env/bin/zuul-cloner ]]; then
elif [[ ! -d tests/common ]]; then elif [[ ! -d tests/common ]]; then
# The tests repo doesn't need a clone, we can just # The tests repo doesn't need a clone, we can just
# symlink it. # symlink it. As zuul v3 clones into a folder called
if [[ "$(basename ${WORKING_DIR})" == "openstack-ansible-tests" ]]; then # 'workspace' we have to use one of its environment
# variables to determine the project name.
if [[ "${ZUUL_SHORT_PROJECT_NAME:-none}" == "openstack-ansible-tests" ]] ||\
[[ "$(basename ${WORKING_DIR})" == "openstack-ansible-tests" ]]; then
ln -s ${WORKING_DIR} ${WORKING_DIR}/tests/common ln -s ${WORKING_DIR} ${WORKING_DIR}/tests/common
# In zuul v3 any dependent repository is placed into
# /home/zuul/src/git.openstack.org, so we check to see
# if there is a tests checkout there already. If so, we
# symlink that and use it.
elif [[ -d "${ZUUL_TESTS_CLONE_LOCATION}" ]]; then
ln -s "${ZUUL_TESTS_CLONE_LOCATION}" ${WORKING_DIR}/tests/common
# Otherwise we're clearly not in zuul or using a previously setup
# repo in some way, so just clone it from upstream.
else else
git clone \ git clone \
https://git.openstack.org/openstack/openstack-ansible-tests \ https://git.openstack.org/openstack/openstack-ansible-tests \

67
zuul.d/jobs.yaml Normal file
View File

@ -0,0 +1,67 @@
---
# Copyright 2017, Rackspace US, 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.
- job:
name: openstack-ansible-dir-ubuntu-xenial
parent: openstack-ansible-functional
nodeset: ubuntu-xenial
vars:
tox_env: dir
- job:
name: openstack-ansible-dir-centos-7
parent: openstack-ansible-functional
nodeset: centos-7
vars:
tox_env: dir
- job:
name: openstack-ansible-dir-opensuse-423
parent: openstack-ansible-functional
nodeset: opensuse-423
vars:
tox_env: dir
- job:
name: openstack-ansible-btrfs-ubuntu-xenial
parent: openstack-ansible-functional
nodeset: ubuntu-xenial
voting: false
vars:
tox_env: btrfs
- job:
name: openstack-ansible-machinectl-ubuntu-xenial
parent: openstack-ansible-functional
nodeset: ubuntu-xenial
voting: false
vars:
tox_env: mnctl
- job:
name: openstack-ansible-overlayfs-ubuntu-xenial
parent: openstack-ansible-functional
nodeset: ubuntu-xenial
voting: false
vars:
tox_env: ofs
- job:
name: openstack-ansible-zfs-ubuntu-xenial
parent: openstack-ansible-functional
nodeset: ubuntu-xenial
voting: false
vars:
tox_env: zfs

32
zuul.d/project.yaml Normal file
View File

@ -0,0 +1,32 @@
---
# Copyright 2017, Rackspace US, 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.
- project:
name: openstack/openstack-ansible-lxc_container_create
check:
jobs:
- openstack-ansible-dir-ubuntu-xenial
- openstack-ansible-dir-centos-7
- openstack-ansible-dir-opensuse-423
- openstack-ansible-btrfs-ubuntu-xenial
- openstack-ansible-machinectl-ubuntu-xenial
- openstack-ansible-overlayfs-ubuntu-xenial
- openstack-ansible-zfs-ubuntu-xenial
gate:
queue: openstack-ansible
jobs:
- openstack-ansible-dir-ubuntu-xenial
- openstack-ansible-dir-centos-7
- openstack-ansible-dir-opensuse-423