| Index: master.nacl.chrome/master.cfg
|
| ===================================================================
|
| --- master.nacl.chrome/master.cfg (revision 67605)
|
| +++ master.nacl.chrome/master.cfg (working copy)
|
| @@ -1,267 +0,0 @@
|
| -# -*- python -*-
|
| -# ex: set syntax=python:
|
| -
|
| -# Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
|
| -# Use of this source code is governed by a BSD-style license that can be
|
| -# found in the LICENSE file.
|
| -
|
| -# This is the buildmaster config file for the 'nacl' bot. It must
|
| -# be installed as 'master.cfg' in your buildmaster's base directory
|
| -# (although the filename can be changed with the --basedir option to
|
| -# 'mktap buildbot master').
|
| -
|
| -# It has one job: define a dictionary named BuildmasterConfig. This
|
| -# dictionary has a variety of keys to control different aspects of the
|
| -# buildmaster. They are documented in docs/config.xhtml .
|
| -
|
| -# This file follows this naming convention:
|
| -# Factories: f_nacl_[dbg/opt/sdk]_[os]
|
| -# Builders: b_nacl_[dbg/opt/sdk]_[os]
|
| -# BuildDir: [dbg/opt/sdk]-[os]
|
| -#
|
| -# os = xp/linux/mac
|
| -
|
| -from buildbot import locks
|
| -from buildbot.changes import svnpoller
|
| -from buildbot.scheduler import Dependent
|
| -from buildbot.scheduler import Scheduler
|
| -from buildbot.scheduler import Triggerable
|
| -
|
| -# Reload all the python files under master and common
|
| -import master
|
| -reload(master)
|
| -import common
|
| -reload(common)
|
| -
|
| -# These modules come from scripts/master, which must be in the PYTHONPATH.
|
| -import build_utils
|
| -import chromium_step
|
| -import master_utils
|
| -from master.factory import nacl_factory
|
| -from master.factory import chromium_factory
|
| -import slaves_list
|
| -
|
| -# These modules come from scripts/common, which must be in the PYTHONPATH.
|
| -import chromium_config as config
|
| -import chromium_utils
|
| -
|
| -ActiveMaster = config.Master.NativeClientChrome
|
| -
|
| -TREE_GATE_KEEPER = ActiveMaster.is_production_host
|
| -GOOD_REVISIONS = False
|
| -
|
| -# This is the dictionary that the buildmaster pays attention to. We also use
|
| -# a shorter alias to save typing.
|
| -c = BuildmasterConfig = {}
|
| -
|
| -
|
| -####### CHANGESOURCES
|
| -
|
| -# the 'change_source' list tells the buildmaster how it should find out about
|
| -# source code changes. Any class which implements IChangeSource can be added
|
| -# to this list: there are several in buildbot/changes/*.py to choose from.
|
| -def NativeClientTreeFileSplitter(path):
|
| - projects = ['native_client']
|
| - for p in projects:
|
| - if path.startswith(p + '/'):
|
| - return (p, path[len(p)+1:])
|
| - return None
|
| -
|
| -# Polls config.Master.nacl_trunk_url for changes
|
| -trunk_poller = svnpoller.SVNPoller(
|
| - svnurl=config.Master.nacl_trunk_url + '/src',
|
| - split_file=NativeClientTreeFileSplitter,
|
| - pollinterval=10)
|
| -
|
| -c['change_source'] = [trunk_poller]
|
| -
|
| -
|
| -####### BUILDERS
|
| -
|
| -# buildbot/process/factory.py provides several BuildFactory classes you can
|
| -# start with, which implement build processes for common targets (GNU
|
| -# autoconf projects, CPAN perl modules, etc). The factory.BuildFactory is the
|
| -# base class, and is configured with a series of BuildSteps. When the build
|
| -# is run, the appropriate buildslave is told to execute each Step in turn.
|
| -
|
| -# the first BuildStep is typically responsible for obtaining a copy of the
|
| -# sources. There are source-obtaining Steps in buildbot/process/step.py for
|
| -# CVS, SVN, and others.
|
| -
|
| -
|
| -# ----------------------------------------------------------------------------
|
| -# FACTORIES
|
| -
|
| -m_win_ch = chromium_factory.ChromiumFactory('src/build', 'win32')
|
| -m_linux_ch = chromium_factory.ChromiumFactory('src/build', 'linux2')
|
| -m_mac_ch = chromium_factory.ChromiumFactory('src/build', 'darwin')
|
| -
|
| -# Some shortcut to simplify the code below.
|
| -F_WIN_CH = m_win_ch.ChromiumNativeClientLatestFactory
|
| -F_LINUX_CH = m_linux_ch.ChromiumNativeClientLatestFactory
|
| -F_MAC_CH = m_mac_ch.ChromiumNativeClientLatestFactory
|
| -
|
| -
|
| -# The identifier of the factory is the build configuration. If two factories
|
| -# are using the same build configuration, they should have the same identifier.
|
| -
|
| -# BuilderTesters using a custom build configuration.
|
| -factories = []
|
| -
|
| -# Add Chromium integration factories.
|
| -factories.append(['xp-nacl-chrome', '1Integration|info', F_WIN_CH(
|
| - 'xp-nacl-chrome',
|
| - mode='google_chrome',
|
| - project='all.sln',
|
| - clobber=True,
|
| - compile_timeout=2400,
|
| - tests=['unit', 'browser_tests', 'check_bins', 'nacl_ui'],
|
| - factory_properties={'disable_mini_installer_test': True})
|
| -])
|
| -factories.append(['mac-nacl-chrome', '1Integration|info', F_MAC_CH(
|
| - 'mac-nacl-chrome',
|
| - mode='google_chrome',
|
| - clobber=True,
|
| - compile_timeout=2400,
|
| - tests=['unit', 'ui', 'media', 'printing',
|
| - 'browser_tests', 'googleurl', 'nacl_ui'],
|
| - factory_properties={})
|
| -])
|
| -factories.append(['hardy64-nacl-chrome', '1Integration|info', F_LINUX_CH(
|
| - 'hardy64-nacl-chrome',
|
| - mode='google_chrome',
|
| - clobber=True,
|
| - compile_timeout=72000,
|
| - tests=['unit', 'ui', 'googleurl', 'media', 'printing',
|
| - 'sizes', 'test_shell', 'memory', 'browser_tests', 'startup',
|
| - 'page_cycler', 'page_cycler_http', 'webkit_unit', 'nacl_ui'],
|
| - options=['--build-tool=make', 'all'],
|
| - factory_properties={
|
| - 'gclient_env': {'GYP_GENERATORS' : 'make'}})
|
| -])
|
| -
|
| -
|
| -
|
| -####### SCHEDULERS
|
| -## configure the Schedulers
|
| -# Main scheduler for all changes in trunk.
|
| -primary_builders = []
|
| -for f in factories:
|
| - primary_builders.append(f[0])
|
| -s_nacl = Scheduler(
|
| - name='nacl',
|
| - branch='native_client',
|
| - treeStableTimer=60,
|
| - builderNames=primary_builders,
|
| -)
|
| -c['schedulers'] = [
|
| - s_nacl,
|
| -]
|
| -
|
| -
|
| -# ----------------------------------------------------------------------------
|
| -# BUILDER DEFINITIONS
|
| -
|
| -# The 'builders' list defines the Builders. Each one is configured with a
|
| -# dictionary, using the following keys:
|
| -# name (required): the name used to describe this bilder
|
| -# slavename (required): which slave to use, must appear in c['slaves']
|
| -# builddir (required): which subdirectory to run the builder in
|
| -# factory (required): a BuildFactory to define how the build is run
|
| -# periodicBuildTime (optional): if set, force a build every N seconds
|
| -# category (optional): it is not used in the normal 'buildbot' meaning. It is
|
| -# used by gatekeeper to determine which steps it should
|
| -# look for to close the tree.
|
| -#
|
| -
|
| -c['builders'] = []
|
| -slaves = slaves_list.SlavesList('slaves.cfg', 'NativeClientChrome')
|
| -for f in factories:
|
| - c['builders'].append({
|
| - 'name': f[0],
|
| - 'slavenames': slaves.GetSlavesName(builder=f[0]),
|
| - 'builddir': f[0],
|
| - 'factory': f[2],
|
| - 'category': '%s' % f[1],
|
| - # Don't enable auto_reboot for people testing locally.
|
| - 'auto_reboot': ActiveMaster.is_production_host,
|
| - })
|
| - if f[0] == 'xp-m32-n32-sdk':
|
| - c['builders'][-1]['max_builds'] = 2
|
| -
|
| -
|
| -####### BUILDSLAVES
|
| -
|
| -# The 'slaves' list defines the set of allowable buildslaves. List all the
|
| -# slaves registered to a builder. Remove dupes.
|
| -c['slaves'] = master_utils.AutoSetupSlaves(c['builders'],
|
| - config.Master.GetBotPassword())
|
| -
|
| -# Make sure everything works together.
|
| -master_utils.VerifySetup(c, slaves)
|
| -
|
| -
|
| -####### STATUS TARGETS
|
| -
|
| -# Adds common status and tools to this master.
|
| -master_utils.AutoSetupMaster(c, ActiveMaster)
|
| -
|
| -# Add more.
|
| -
|
| -if TREE_GATE_KEEPER:
|
| - import gatekeeper
|
| - # This is the list of the builder categories and the corresponding critical
|
| - # steps. If one critical step fails, gatekeeper will close the tree
|
| - # automatically.
|
| - categories_steps = {
|
| - '': [
|
| - 'update scripts', 'update',
|
| - 'clobber', 'clobber_packages',
|
| - ],
|
| - 'info': [],
|
| - 'closer': [
|
| - 'update scripts', 'update',
|
| - 'clobber', 'clobber_packages', 'precompile', 'compile',
|
| - 'scons_compile', 'gyp_compile', 'build_packages',
|
| - 'cooking_tarball', 'selenium',
|
| - 'small_tests', 'medium_tests', 'large_tests',
|
| - 'hand_tests', 'smoke_tests',
|
| - 'backup_plugin', 'install_plugin', 'start_vncserver',
|
| - 'stop_vncserver', 'restore_plugin'],
|
| - }
|
| - exclusions = { }
|
| - forgiving_steps = ['update scripts', 'update', 'svnkill', 'taskkill',
|
| - 'archived build']
|
| - c['status'].append(gatekeeper.GateKeeper(
|
| - fromaddr=ActiveMaster.from_address,
|
| - categories_steps=categories_steps,
|
| - exclusions=exclusions,
|
| - relayhost=config.Master.smtp,
|
| - subject='buildbot %(result)s in %(projectName)s on %(builder)s, '
|
| - 'revision %(revision)s',
|
| - extraRecipients=ActiveMaster.tree_closing_notification_recipients,
|
| - tree_status_url=ActiveMaster.tree_status_url,
|
| - lookup=master_utils.FilterDomain(),
|
| - forgiving_steps=forgiving_steps))
|
| -
|
| -if GOOD_REVISIONS:
|
| - import goodrevisions
|
| - # This is the list of builders with their respective list of critical steps
|
| - # that all need to succeed to mark a revision as successful. A single failure
|
| - # in any of the steps of any of the builders will mark the revision as failed.
|
| - all_steps = [
|
| - 'update',
|
| - 'compile',
|
| - 'small_tests',
|
| - 'medium_tests',
|
| - 'large_tests',
|
| - ]
|
| - c['status'].append(goodrevisions.GoodRevisions(
|
| - good_revision_steps={'': all_steps},
|
| - store_revisions_url=ActiveMaster.store_revisions_url))
|
| -
|
| -
|
| -####### PROJECT IDENTITY
|
| -
|
| -# Buildbot master url:
|
| -c['buildbotURL'] = 'http://buildbot.jail.google.com/buildbot/nacl/'
|
|
|