forked from bartvdbraak/blender
Update buildbot config to latest actual version
This commit is contained in:
parent
5f3fc624a5
commit
cf9d03494b
@ -3,6 +3,52 @@
|
|||||||
|
|
||||||
# <pep8 compliant>
|
# <pep8 compliant>
|
||||||
|
|
||||||
|
"""
|
||||||
|
Stock Twisted directory lister doesn't provide any information about last file
|
||||||
|
modification time, we hack the class a bit in order to have such functionaliity
|
||||||
|
:)
|
||||||
|
"""
|
||||||
|
|
||||||
|
from buildbot.status.web.base import DirectoryLister
|
||||||
|
|
||||||
|
|
||||||
|
def get_files_and_directories(self, directory):
|
||||||
|
from twisted.web.static import (getTypeAndEncoding,
|
||||||
|
formatFileSize)
|
||||||
|
import urllib
|
||||||
|
import cgi
|
||||||
|
import time
|
||||||
|
import os
|
||||||
|
files = []
|
||||||
|
dirs = []
|
||||||
|
for path in directory:
|
||||||
|
url = urllib.quote(path, "/")
|
||||||
|
escapedPath = cgi.escape(path)
|
||||||
|
lastmodified = time.ctime(os.path.getmtime(
|
||||||
|
os.path.join(self.path, path)))
|
||||||
|
if os.path.isdir(os.path.join(self.path, path)):
|
||||||
|
url = url + '/'
|
||||||
|
dirs.append({'text': escapedPath + "/", 'href': url,
|
||||||
|
'size': '', 'type': '[Directory]',
|
||||||
|
'encoding': '',
|
||||||
|
'lastmodified': lastmodified})
|
||||||
|
else:
|
||||||
|
mimetype, encoding = getTypeAndEncoding(path, self.contentTypes,
|
||||||
|
self.contentEncodings,
|
||||||
|
self.defaultType)
|
||||||
|
try:
|
||||||
|
size = os.stat(os.path.join(self.path, path)).st_size
|
||||||
|
except OSError:
|
||||||
|
continue
|
||||||
|
files.append({
|
||||||
|
'text': escapedPath, "href": url,
|
||||||
|
'type': '[%s]' % mimetype,
|
||||||
|
'encoding': (encoding and '[%s]' % encoding or ''),
|
||||||
|
'size': formatFileSize(size),
|
||||||
|
'lastmodified': lastmodified})
|
||||||
|
return dirs, files
|
||||||
|
DirectoryLister._getFilesAndDirectories = get_files_and_directories
|
||||||
|
|
||||||
# Dictionary that the buildmaster pays attention to.
|
# Dictionary that the buildmaster pays attention to.
|
||||||
c = BuildmasterConfig = {}
|
c = BuildmasterConfig = {}
|
||||||
|
|
||||||
@ -37,37 +83,34 @@ c['change_source'] = GitPoller(
|
|||||||
# Decide how to react to incoming changes.
|
# Decide how to react to incoming changes.
|
||||||
|
|
||||||
# from buildbot.scheduler import Scheduler
|
# from buildbot.scheduler import Scheduler
|
||||||
from buildbot.schedulers import timed
|
from buildbot.schedulers import timed, forcesched
|
||||||
|
|
||||||
c['schedulers'] = []
|
c['schedulers'] = []
|
||||||
|
|
||||||
|
|
||||||
|
def schedule_force_build(name):
|
||||||
|
c['schedulers'].append(forcesched.ForceScheduler(name='force ' + name,
|
||||||
|
builderNames=[name],
|
||||||
|
branch=forcesched.FixedParameter(name="branch", default=""),
|
||||||
|
revision=forcesched.FixedParameter(name="revision", default=""),
|
||||||
|
repository=forcesched.FixedParameter(name="repository", default=""),
|
||||||
|
project=forcesched.FixedParameter(name="project", default=""),
|
||||||
|
properties=[]))
|
||||||
|
|
||||||
|
|
||||||
def schedule_build(name, hour, minute=0):
|
def schedule_build(name, hour, minute=0):
|
||||||
c['schedulers'].append(timed.Nightly(name='nightly ' + name,
|
c['schedulers'].append(timed.Nightly(name='nightly ' + name,
|
||||||
|
branch=None, # default branch
|
||||||
builderNames=[name],
|
builderNames=[name],
|
||||||
hour=hour,
|
hour=hour,
|
||||||
minute=minute))
|
minute=minute))
|
||||||
|
|
||||||
"""
|
|
||||||
schedule_cycle = 4
|
|
||||||
|
|
||||||
for i in range(0, schedule_cycle):
|
|
||||||
names = []
|
|
||||||
for j in range(0, len(buildernames)):
|
|
||||||
if j % schedule_cycle == i:
|
|
||||||
names += [buildernames[j]]
|
|
||||||
|
|
||||||
print(names)
|
|
||||||
c['schedulers'].append(timed.Nightly(name='nightly' + str(i),
|
|
||||||
builderNames=names,
|
|
||||||
hour=3+i,
|
|
||||||
minute=0))
|
|
||||||
"""
|
|
||||||
|
|
||||||
# BUILDERS
|
# BUILDERS
|
||||||
#
|
#
|
||||||
# The 'builders' list defines the Builders, which tell Buildbot how to perform a build:
|
# The 'builders' list defines the Builders, which tell Buildbot how to
|
||||||
# what steps, and which slaves can execute them. Note that any particular build will
|
# perform a build: what steps, and which slaves can execute them.
|
||||||
# only take place on one slave.
|
# Note that any particular build will only take place on one slave.
|
||||||
|
|
||||||
from buildbot.process.factory import BuildFactory
|
from buildbot.process.factory import BuildFactory
|
||||||
from buildbot.steps.source import SVN
|
from buildbot.steps.source import SVN
|
||||||
@ -76,7 +119,6 @@ from buildbot.steps.shell import ShellCommand
|
|||||||
from buildbot.steps.shell import Compile
|
from buildbot.steps.shell import Compile
|
||||||
from buildbot.steps.shell import Test
|
from buildbot.steps.shell import Test
|
||||||
from buildbot.steps.transfer import FileUpload
|
from buildbot.steps.transfer import FileUpload
|
||||||
# from buildbot.steps.transfer import FileDownload
|
|
||||||
from buildbot.steps.master import MasterShellCommand
|
from buildbot.steps.master import MasterShellCommand
|
||||||
from buildbot.config import BuilderConfig
|
from buildbot.config import BuilderConfig
|
||||||
|
|
||||||
@ -86,7 +128,8 @@ c['builders'] = []
|
|||||||
buildernames = []
|
buildernames = []
|
||||||
|
|
||||||
|
|
||||||
def add_builder(c, name, libdir, factory, branch='', rsync=False, hour=3, minute=0):
|
def add_builder(c, name, libdir, factory, branch='',
|
||||||
|
rsync=False, hour=3, minute=0):
|
||||||
slavenames = []
|
slavenames = []
|
||||||
|
|
||||||
for slave in master_private.slaves:
|
for slave in master_private.slaves:
|
||||||
@ -95,31 +138,65 @@ def add_builder(c, name, libdir, factory, branch='', rsync=False, hour=3, minute
|
|||||||
|
|
||||||
if len(slavenames) > 0:
|
if len(slavenames) > 0:
|
||||||
f = factory(name, libdir, branch, rsync)
|
f = factory(name, libdir, branch, rsync)
|
||||||
c['builders'].append(BuilderConfig(name=name, slavenames=slavenames, factory=f, category='blender'))
|
c['builders'].append(BuilderConfig(name=name,
|
||||||
|
slavenames=slavenames,
|
||||||
|
factory=f,
|
||||||
|
category='blender'))
|
||||||
buildernames.append(name)
|
buildernames.append(name)
|
||||||
|
|
||||||
schedule_build(name, hour, minute)
|
schedule_build(name, hour, minute)
|
||||||
|
schedule_force_build(name)
|
||||||
|
|
||||||
# common steps
|
# common steps
|
||||||
|
|
||||||
|
|
||||||
def git_submodule_step(submodule):
|
def git_submodule_step(submodule):
|
||||||
return Git(name=submodule+'.git', repourl='git://git.blender.org/' + submodule + '.git', mode='update', workdir=submodule + '.git')
|
return Git(name=submodule + '.git',
|
||||||
|
repourl='git://git.blender.org/' + submodule + '.git',
|
||||||
|
mode='update',
|
||||||
|
workdir=submodule + '.git')
|
||||||
|
|
||||||
|
|
||||||
def git_step(branch=''):
|
def git_step(branch=''):
|
||||||
if branch:
|
if branch:
|
||||||
return Git(name='blender.git', repourl='git://git.blender.org/blender.git', mode='update', branch=branch, workdir='blender.git', submodules=True)
|
return Git(name='blender.git',
|
||||||
|
repourl='git://git.blender.org/blender.git',
|
||||||
|
mode='update',
|
||||||
|
branch=branch,
|
||||||
|
workdir='blender.git',
|
||||||
|
submodules=True)
|
||||||
else:
|
else:
|
||||||
return Git(name='blender.git', repourl='git://git.blender.org/blender.git', mode='update', workdir='blender.git', submodules=True)
|
return Git(name='blender.git',
|
||||||
|
repourl='git://git.blender.org/blender.git',
|
||||||
|
mode='update',
|
||||||
|
workdir='blender.git',
|
||||||
|
submodules=True)
|
||||||
|
|
||||||
|
|
||||||
def git_submodules_update():
|
def git_submodules_update():
|
||||||
command = ['git', 'submodule', 'foreach', '--recursive', 'git', 'pull', 'origin', 'master']
|
command = ['git', 'submodule', 'foreach', '--recursive',
|
||||||
return ShellCommand(name='Submodules Update', command=command, description='updating', descriptionDone='up to date', workdir='blender.git')
|
'git', 'pull', 'origin', 'master']
|
||||||
|
return ShellCommand(name='Submodules Update',
|
||||||
|
command=command,
|
||||||
|
description='updating',
|
||||||
|
descriptionDone='up to date',
|
||||||
|
workdir='blender.git')
|
||||||
|
|
||||||
|
|
||||||
def lib_svn_step(dir):
|
def lib_svn_step(dir):
|
||||||
return SVN(name='lib svn', baseURL='https://svn.blender.org/svnroot/bf-blender/%%BRANCH%%/lib/' + dir, mode='update', defaultBranch='trunk', workdir='lib/' + dir)
|
return SVN(name='lib svn',
|
||||||
|
baseURL='https://svn.blender.org/svnroot/bf-blender/%%BRANCH%%/lib/' + dir,
|
||||||
|
mode='update',
|
||||||
|
defaultBranch='trunk',
|
||||||
|
workdir='lib/' + dir)
|
||||||
|
|
||||||
|
|
||||||
def rsync_step(id, branch, rsync_script):
|
def rsync_step(id, branch, rsync_script):
|
||||||
return ShellCommand(name='rsync', command=['python', rsync_script, id, branch], description='uploading', descriptionDone='uploaded', workdir='install')
|
return ShellCommand(name='rsync',
|
||||||
|
command=['python', rsync_script, id, branch],
|
||||||
|
description='uploading',
|
||||||
|
descriptionDone='uploaded',
|
||||||
|
workdir='install')
|
||||||
|
|
||||||
# generic builder
|
# generic builder
|
||||||
|
|
||||||
@ -136,21 +213,38 @@ def generic_builder(id, libdir='', branch='', rsync=False):
|
|||||||
if libdir != '':
|
if libdir != '':
|
||||||
f.addStep(lib_svn_step(libdir))
|
f.addStep(lib_svn_step(libdir))
|
||||||
|
|
||||||
for submodule in ('blender-translations', 'blender-addons', 'blender-addons-contrib', 'scons'):
|
for submodule in ('blender-translations',
|
||||||
|
'blender-addons',
|
||||||
|
'blender-addons-contrib',
|
||||||
|
'scons'):
|
||||||
f.addStep(git_submodule_step(submodule))
|
f.addStep(git_submodule_step(submodule))
|
||||||
|
|
||||||
f.addStep(git_step(branch))
|
f.addStep(git_step(branch))
|
||||||
f.addStep(git_submodules_update())
|
f.addStep(git_submodules_update())
|
||||||
|
|
||||||
f.addStep(Compile(command=['python', compile_script, id], timeout=3600))
|
f.addStep(Compile(command=['python', compile_script, id], timeout=3600))
|
||||||
f.addStep(Test(command=['python', test_script, id]))
|
f.addStep(Test(command=['python', test_script, id]))
|
||||||
f.addStep(ShellCommand(name='package', command=['python', pack_script, id, branch], description='packaging', descriptionDone='packaged'))
|
f.addStep(ShellCommand(name='package',
|
||||||
|
command=['python', pack_script, id, branch],
|
||||||
|
description='packaging',
|
||||||
|
descriptionDone='packaged'))
|
||||||
if rsync:
|
if rsync:
|
||||||
f.addStep(rsync_step(id, branch, rsync_script))
|
f.addStep(rsync_step(id, branch, rsync_script))
|
||||||
elif id.find('cmake') != -1:
|
elif id.find('cmake') != -1:
|
||||||
f.addStep(FileUpload(name='upload', slavesrc='buildbot_upload.zip', masterdest=filename, maxsize=150 * 1024 * 1024))
|
f.addStep(FileUpload(name='upload',
|
||||||
|
slavesrc='buildbot_upload.zip',
|
||||||
|
masterdest=filename,
|
||||||
|
maxsize=150 * 1024 * 1024))
|
||||||
else:
|
else:
|
||||||
f.addStep(FileUpload(name='upload', slavesrc='buildbot_upload.zip', masterdest=filename, maxsize=150 * 1024 * 1024, workdir='install'))
|
f.addStep(FileUpload(name='upload',
|
||||||
f.addStep(MasterShellCommand(name='unpack', command=['python', unpack_script, filename], description='unpacking', descriptionDone='unpacked'))
|
slavesrc='buildbot_upload.zip',
|
||||||
|
masterdest=filename,
|
||||||
|
maxsize=150 * 1024 * 1024,
|
||||||
|
workdir='install'))
|
||||||
|
f.addStep(MasterShellCommand(name='unpack',
|
||||||
|
command=['python', unpack_script, filename],
|
||||||
|
description='unpacking',
|
||||||
|
descriptionDone='unpacked'))
|
||||||
return f
|
return f
|
||||||
|
|
||||||
# builders
|
# builders
|
||||||
@ -195,15 +289,16 @@ authz_cfg = authz.Authz(
|
|||||||
# change any of these to True to enable; see the manual for more
|
# change any of these to True to enable; see the manual for more
|
||||||
# options
|
# options
|
||||||
gracefulShutdown=False,
|
gracefulShutdown=False,
|
||||||
forceBuild='auth', # use this to test your slave once it is set up
|
forceBuild=True, # use this to test your slave once it is set up
|
||||||
forceAllBuilds=False,
|
forceAllBuilds=False,
|
||||||
pingBuilder=False,
|
pingBuilder=False,
|
||||||
stopBuild='auth',
|
stopBuild=True,
|
||||||
stopAllBuilds=False,
|
stopAllBuilds=False,
|
||||||
cancelPendingBuild='auth',
|
cancelPendingBuild=True,
|
||||||
)
|
)
|
||||||
|
|
||||||
c['status'].append(html.WebStatus(http_port=8010, authz=authz_cfg))
|
c['status'].append(html.WebStatus(http_port=8010, authz=authz_cfg))
|
||||||
|
#c['status'].append(html.WebStatus(http_port=8010))
|
||||||
|
|
||||||
# PROJECT IDENTITY
|
# PROJECT IDENTITY
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user