You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			107 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			107 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| ===================================================================
 | |
| 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.
 |