Workflow: RDO Trunk repos

RDO Trunk repositories are built using the most recent commit(or from the pin to a commit/tag/branch if source-branch is set for a release in rdoinfo) from each of the OpenStack projects defined for a release. We host the RDO Trunk repositories at On that server, you will find several repositories:

CentOS 7 master, with everything from master repo is not tested by any CI job, this repo is created as a result of building recent commits to get packaging issues early for the projects which are pinned in rdoinfo.

These repos contains packages build for each OpenStack project defined for a particular release in rdoinfo. This mapping of repo and release is as follows:-

  • [CentOS 7 master, with everything from master] with current release rdoinfo tag i.e train
  • [CentOS 7 master, using versions from upper-constraints] with current release rdoinfo tag i.e train-uc
  • [CentOS 7 stable releases for the currently supported versions] with stable release rdoinfo tag other than current release train, train-uc
  • [Fedora 28 master] with current release rdoinfo tag i.e train-uc

The upper-constraints based repositories

The gate jobs for each OpenStack project use a common set of dependencies, defined by the requirements repository. One of the files on that repository is upper-constraints.txt, which contains the latest supported version for each component.

Why is this file important? It defines an upper cap for every gate job, meaning those are the versions all OpenStack projects are being tested against. For example, if the specified version for python-novaclient in the file is 9.0.0, we can safely assume that this version will work fine for all projects, but we cannot say the same for any commit beyond that point.

This is also important when packaging, because we want our generated repositories to be usable by upstream CIs, so we need to provide a set of packages that matches the versions available in the upper-constraints.txt file. Thus, we have two separate repositories for master:

For stable releases, we also follow the upper-constraints approach.

Hashed repos and special repos

When each new upstream commit is built, a repository is created with the new package and the latest versions from every other package built by RDO Trunk. This new repository is located in a hashed URL. The details can be found at This hash is built using:

Besides hashed repositories, we have some special directories, created as symlinks to hashed repos:

  • current points to the repository with contains the last successfully built package from every project.
  • consistent points to the latest repository where none of the packages have current build failures.
  • current-passed-ci points to the last consistent repository that passed all the promotion CI tests.

← DLRN | → Promotion pipeline | ↑ TOC