DO NOT send Pull Requests here, send reviews to
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Failed to load latest commit information.
dlrn Fix mock_base_packages list for the koji driver Sep 13, 2018
doc Add option to use rhpkg in KojiBuildDriver Aug 6, 2018
playbooks Update commit to be imported in functional tests Aug 6, 2018
scripts Merge "Allow specifying a tag in" Sep 17, 2018
.coveragerc Rename delorean to dlrn in the DLRN codebase Mar 31, 2016
.gitignore Rename delorean to dlrn in the DLRN codebase Mar 31, 2016
.gitreview Change .gitreview to use Apr 27, 2017
.mailmap Initial commit May 20, 2014
.zuul.yaml zuul.yaml: use generic tox-py35 job Jan 24, 2018
CONTRIBUTING.rst Fix code block rendering in CONTRIBUTING.rst Jul 4, 2017
HACKING.rst Adding some basic documentation Jan 21, 2015
LICENSE Initial commit May 20, 2014 Initial commit May 20, 2014
README.rst Fix README typo Aug 5, 2017
alembic.ini Add Alembic support Jul 1, 2016
babel.cfg Initial commit May 20, 2014
bindep.txt Add support for bindep.txt Jun 29, 2018
projects.ini Add option to use rhpkg in KojiBuildDriver Aug 6, 2018
requirements.txt Revert "Pin rdopkg<0.47.0 due to backward incompatibility" Aug 16, 2018
setup.cfg User management command-line tool Apr 10, 2018 First commit to start working on test coverage Feb 4, 2015
test-requirements.txt oslosphinx not oslo.sphinx Jul 1, 2016
tox.ini Allow unit test selection through tox Aug 2, 2018



DLRN builds and maintains yum repositories following OpenStack upstream commit streams. (DLRN is not an acronym or an abbreviation, and it can be pronounced "dee el arr en".)

Documentation is available at


# yum install git createrepo python-virtualenv mock gcc \
              redhat-rpm-config rpmdevtools httpd libffi-devel \
              openssl-devel yum-utils

Add the user you intend to run as to the mock group and login again.

$ git clone

If you want to serve the built packages and the status reports, enable the httpd service, and then either add a section in the server configuration to map a URL to the data directories, or create a symbolic link:

# systemctl start httpd
# cd /var/www/html
# ln -s <datadir>/repos .


$ cd DLRN
$ virtualenv ../dlrn-venv
$ . ../dlrn-venv/bin/activate
$ pip install --upgrade pip
$ pip install -r requirements.txt
$ python develop

Edit projects.ini if needed.


Some of the projects require others to build. As a result, use the special option --order to build in the order computed from the BuildRequires and Requires fields of the spec files when you bootstrap your repository.

$ dlrn --order

When using this special option, a special variable repo_bootstrap is defined in the specs, with a value of 1. You can use this variable if needed, to break dependency loops between packages. For example:

%if 0%{?repo_bootstrap} == 0
BuildRequires: package-with-circular-dependency


Once all the packages have been built once, you can get back to build the packages in the order of the timestamps of the commits.

$ dlrn


If you interrupt dlrn during mock build you might get an error

OSError: [Errno 16] Device or resource busy: '/var/lib/mock/dlrn-fedora-x86_64/root/var/cache/yum'

Solution is to clear left-over bind mount as root:

# umount /var/lib/mock/dlrn-fedora-x86_64/root/var/cache/yum

Other requirements

If the git clone operation fails for a package, DLRN will try to remove the source directory using sudo. Please make sure the user running DLRN can run rm -rf /path/to/dlrn/data/* without being asked for a password, otherwise DLRN will fail to process new commits.