123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 |
- ===================================================================
- How To Add Your Build Configuration To LLVM Buildbot Infrastructure
- ===================================================================
- Introduction
- ============
- This document contains information about adding a build configuration and
- buildslave to private slave builder to LLVM Buildbot Infrastructure.
- Buildmasters
- ============
- There are two buildmasters running.
- * The main buildmaster at `<http://lab.llvm.org:8011>`_. All builders attached
- to this machine will notify commit authors every time they break the build.
- * The staging buildbot at `<http://lab.llvm.org:8014>`_. All builders attached
- to this machine will be completely silent by default when the build is broken.
- Builders for experimental backends should generally be attached to this
- buildmaster.
- Steps To Add Builder To LLVM Buildbot
- =====================================
- Volunteers can provide their build machines to work as build slaves to
- public LLVM Buildbot.
- Here are the steps you can follow to do so:
- #. Check the existing build configurations to make sure the one you are
- interested in is not covered yet or gets built on your computer much
- faster than on the existing one. We prefer faster builds so developers
- will get feedback sooner after changes get committed.
- #. The computer you will be registering with the LLVM buildbot
- infrastructure should have all dependencies installed and you can
- actually build your configuration successfully. Please check what degree
- of parallelism (-j param) would give the fastest build. You can build
- multiple configurations on one computer.
- #. Install buildslave (currently we are using buildbot version 0.8.5).
- Depending on the platform, buildslave could be available to download and
- install with your package manager, or you can download it directly from
- `<http://trac.buildbot.net>`_ and install it manually.
- #. Create a designated user account, your buildslave will be running under,
- and set appropriate permissions.
- #. Choose the buildslave root directory (all builds will be placed under
- it), buildslave access name and password the build master will be using
- to authenticate your buildslave.
- #. Create a buildslave in context of that buildslave account. Point it to
- the **lab.llvm.org** port **9990** (see `Buildbot documentation,
- Creating a slave
- <http://docs.buildbot.net/current/tutorial/firstrun.html#creating-a-slave>`_
- for more details) by running the following command:
- .. code-block:: bash
- $ buildslave create-slave <buildslave-root-directory> \
- lab.llvm.org:9990 \
- <buildslave-access-name> <buildslave-access-password>
- To point a slave to silent master please use lab.llvm.org:9994 instead
- of lab.llvm.org:9990.
- #. Fill the buildslave description and admin name/e-mail. Here is an
- example of the buildslave description::
- Windows 7 x64
- Core i7 (2.66GHz), 16GB of RAM
- g++.exe (TDM-1 mingw32) 4.4.0
- GNU Binutils 2.19.1
- cmake version 2.8.4
- Microsoft(R) 32-bit C/C++ Optimizing Compiler Version 16.00.40219.01 for 80x86
- #. Make sure you can actually start the buildslave successfully. Then set
- up your buildslave to start automatically at the start up time. See the
- buildbot documentation for help. You may want to restart your computer
- to see if it works.
- #. Send a patch which adds your build slave and your builder to zorg.
- * slaves are added to ``buildbot/osuosl/master/config/slaves.py``
- * builders are added to ``buildbot/osuosl/master/config/builders.py``
- Please make sure your builder name and its builddir are unique through the file.
- It is possible to whitelist email addresses to unconditionally receive notifications
- on build failure; for this you'll need to add an ``InformativeMailNotifier`` to
- ``buildbot/osuosl/master/config/status.py``. This is particularly useful for the
- staging buildmaster which is silent otherwise.
- #. Send the buildslave access name and the access password directly to
- `Galina Kistanova <mailto:gkistanova@gmail.com>`_, and wait till she
- will let you know that your changes are applied and buildmaster is
- reconfigured.
- #. Check the status of your buildslave on the `Waterfall Display
- <http://lab.llvm.org:8011/waterfall>`_ to make sure it is connected, and
- ``http://lab.llvm.org:8011/buildslaves/<your-buildslave-name>`` to see
- if administrator contact and slave information are correct.
- #. Wait for the first build to succeed and enjoy.
|