| =================================================================== |
| 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. |