ff64ea937c
Previously, artg_change_list in role build-test-packages would default
to an empty list if not defined. Now, artg_change_list will default to
job.artg_change_list which itself defaults to empty list. This allows
us to specify variable artg_change_list in Zuul jobs. If role
build-test-packages is executed locally, then a locally defined
artg_change_list still has higher precedence, as expected.
Previously, if a change had e.g. a 'Depends-On:' statement in its
commit message, the artg_change_list variable would be overwritten
with patches defined in the 'Depends-On:' statements. Now, patches
listed in 'Depends-On:' will be added to the artg_change_list
variable instead of overwriting its contents.
Both functionality is required in our TripleO jobs in the Ansible
OpenStack collection. There we want to build the RPM of
openstacksdk from its upstream master branch instead of using the
pinned version provided by RDO [1].
[1]
|
||
---|---|---|
.. | ||
defaults | ||
library | ||
meta | ||
molecule/default | ||
tasks | ||
templates | ||
README.md |
build-test-packages
An Ansible role for generating custom RPMSs from upstream Gerrit changes in the TripleO project using DLRN. This repo then can be injected in the tested environment, a repo file created and a yum update should start using the built RPMs.
Requirements
Role Variables
local_working_dir
-- the directory where tripleo-quickstart is locatedbuild_repo_dir
-- the directory where the DLRN repo is built. The variable defaults to the home directory of the user.artg_dlrn_repo_url
-- the URL of the DLRN repositoryartg_rdoinfo_repo_url
-- the URL of the rdoinfo repository that contains the project definitions for DLRNartg_compressed_gating_repo
-- a full path to a compressed repository that contains all the generated rpmsartg_change_list
-- a list of changes to gate. Only needed when not running in Zuul or Gerrit (see below). The format is:artg_requirements
-- used in roles mode, the requirements file to use for replacing the gated rolesartg_skipped_projects
-- a list of projects that are not going to be gated. This is useful if the project is directly checked out by the gate job as this retains "Depends-On" functionality for the rest of the projects. Also useful to skip projects that DLRN cannot build.artg_repos_dir
-- Root directory which contains project directories with sources for build.artg_build_one
-- Boolean to indicate if dlrn should build one package at a time. If set to false, dlrn will be run to build all the required packages in one invocation of dlrn.dlrn_target
-- Target for the DLRN build Can be something like centos or fedora. Defaults to centos.dlrn_baseurl
-- URL used by DLRN to get the repo definitions when building packagesdlrn_use_local_mirrors
-- use the local repo definitions from /etc/yum.repos.d/ for CentOS and DLRN while building packages; used upstream
Example artg_change_list for just code changes:
artg_change_list:
- host: "review.opendev.org"
project: "openstack/tripleo-heat-templates"
branch: "master"
refspec: "refs/changes/1/123456/1"
- host: ...
Example artg_change_list for code changes and package changes:
artg_change_list:
- host: "review.opendev.org"
project: "openstack/tripleo-heat-templates"
branch: "master"
refspec: "refs/changes/1/123456/1"
distgit:
host: "ssh://user@review.rdoproject.org"
project: "openstack/tripleo-heat-templates-distgit"
refspec: "refs/changes/1/123456/1"
- host: ...
Gating with Zuul or Jenkins
The role can also work with Zuul and Jenkins based gating jobs.
In case of Zuul, the role uses ZUUL_HOST
and ZUUL_CHANGES
vars to parse the
full set of dependent changes that were previously
resolved by Zuul.
If we're running in a Jenkins environment with the
Gerrit Trigger plugin,
GERRIT_HOST
, GERRIT_CHANGE_ID
, GERRIT_BRANCH
and
GERRIT_PATCHSET_REVISION
are used to detect the gated change. The role then
searches for "Depends-On:" lines in the commit message (and recursively in the
commit messages of the dependent changes) and adds all of them to the gating
list. This happens through Gerrit server's public REST API.
Example Playbook
---
- name: Build custom RPMs
hosts: virthost
roles:
- build-test-packages
License
Apache
Author Information
RDO-CI Team