How to setup britney ==================== This document describes how to install, configure and run britney in your infrastructure. Installing britney ------------------ At the moment, the preferred way to install britney is to clone the source repo and run britney directly from the git checkout. Configuring britney ------------------- This is a very brief intro to the steps required to setup a Britney instance. * Copy ``britney.conf.template`` and edit it to suit your purpose - If you want Britney to bootstrap your target suite, you probably want to add all architectures to ``NEW_ARCHES`` and ``BREAK_ARCHES`` for a few runs * Create the following files (they can be empty): * ``$STATE_DIR/age-policy-dates`` * ``$STATE_DIR/age-policy-urgencies`` * ``$STATE_DIR/rc-bugs-unstable`` * ``$STATE_DIR/rc-bugs-testing`` * ``$STATE_DIR/piuparts-summary-testing.json`` * ``$STATE_DIR/piuparts-summary-unstable.json`` * Run ``./britney.py -c $BRITNEY_CONF -v [--dry-run]`` to test the run * Setup a cron-/batch-job that: * (Optionally) Updates the rc-bugs files * (Optionally) Updates the $STATE_DIR/age-policy-urgencies * (Optionally) Updates the piuparts summary files * Runs Britney * Consume the results from Britney (See :ref:`using-the-results-from-britney` for more information) hints - Configuring who can provide which hints ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Britney reads all hints from a set of `hints` files. These files must be placed in the directory denoted by the ``HINTSDIR`` configuration. This is complimented with the ``HINTS_<NAME>`` configurations that defines a "hint file" and the related hint permissions for it. For each ``HINTS_<NAME>`` configuration, britney will attempt to read ``<HINTSDIR>/<name>``. Note that it lowercases ``<NAME>`` when looking for the file. Configuration example:: HINTSDIR = /etc/britney2/hints HINTS_ANNA = ALL HINTS_JOHN = STANDARD HINTS_FREEZE = block block-all block-udeb HINTS_AUTO-REMOVALS = remove In the above example, we have defined 4 hints files named ``anna``, ``john``, ``freeze`` and ``auto-removals``. These must be placed in ``/etc/britney2/hints`` and be readable by britney. Furthermore, they must be writable by (only) the people that are allowed to use the particular hints file (apply ``chown``, ``chmod`` and ``setfacl`` as neccesary). The values on the right hand side of the `=` decides which hints are permitted in the files. With the above definitions: * The file ``anna`` may use any known hint (including potentially dangerous ones like ``force`` and ``force-hint``) * The file ``john`` may use most of the known hints. The set called STANDARD includes a lot of hints for overriding most policies when it can be done without (additional) side-effects. However, it excludes ``force`` and ``force-hint`` as they can cause unintentional results. * The file ``freeze`` can use any of the hints ``block``, ``block-all`` and ``block-udeb``. * The file ``auto-removals`` can only use the hint called ``remove``. There are no fixed rules for how to use hints files. Though usually, each person with permissions to give hints to britney will have their own hint file along with write permissions for that file. It can also make sense to create hint files for "roles". Like in the above example there are two human hinters (``anna`` and ``john``) plus two non-human hinters (``freeze`` and ``auto-removals``). Please see :doc:`hints` for which hints are available and what they can do. .. _using-the-results-from-britney: Using the results from Britney ------------------------------ Britney optionally generates a number of files that may be useful for further processing. * ``HEIDI_OUTPUT`` can be used with ``dak control-suite``. Example:: cut -d" " -f1-3 < ${HEIDI_OUTPUT} | dak control-suite --set ${TARGET_SUITE} [--britney] * ``HEIDI_DELTA_OUTPUT`` is a variant of ``HEIDI_OUTPUT`` that represent the result as a delta rather than a full selection. * ``EXCUSES_YAML_OUTPUT`` provides a machine-readable output about which packages comply with the active policies and which does not.