Commit 2ce13ba4 authored by Russ Cox's avatar Russ Cox

dashboard: builder tweaks

R=agl1
CC=golang-dev
https://golang.org/cl/194116
parent 424f9ca6
...@@ -6,11 +6,15 @@ The files in this directory constitute the continuous builder: ...@@ -6,11 +6,15 @@ The files in this directory constitute the continuous builder:
godashboard/: An AppEngine that acts as a server godashboard/: An AppEngine that acts as a server
builder.sh, buildcontrol.sh: used by the build slaves builder.sh, buildcontrol.sh: used by the build slaves
buildcron.sh: a build loop that can be run regularly via cron
If you wish to run a Go builder, please email golang-dev@googlegroups.com If you wish to run a Go builder, please email golang-dev@googlegroups.com
Setting up a Go builder: To set up a Go builder automatically, run buildcron.sh
(you might want to read it first to see what it does).
To set up a Go builder by hand:
* (Optional) create a new user 'gobuild' * (Optional) create a new user 'gobuild'
* Edit ~gobuild/.bash_profile and add the following: * Edit ~gobuild/.bash_profile and add the following:
......
...@@ -35,12 +35,12 @@ def main(args): ...@@ -35,12 +35,12 @@ def main(args):
buildport = int(os.environ['BUILDPORT']) buildport = int(os.environ['BUILDPORT'])
try: try:
buildkey = file('%s/.gobuildkey' % os.environ['GOROOT'], 'r').read().strip() buildkey = file('%s/.gobuildkey-%s' % (os.environ['HOME'], os.environ['BUILDER']), 'r').read().strip()
except IOError: except IOError:
try: try:
buildkey = file('%s/.gobuildkey' % os.environ['HOME'], 'r').read().strip() buildkey = file('%s/.gobuildkey' % os.environ['HOME'], 'r').read().strip()
except IOError: except IOError:
print >>sys.stderr, "Need key in $GOROOT/.gobuildkey or ~/.gobuildkey" print >>sys.stderr, "Need key in ~/.gobuildkey-%s or ~/.gobuildkey" % os.environ['BUILDER']
return return
if args[1] == 'init': if args[1] == 'init':
......
#!/bin/sh
# Copyright 2010 The Go 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 script can be run to create a new builder and then
# to keep it running via cron. First, run it by hand until it
# starts up without errors and can run the loop. Then, once
# you're confident that it works, add this to your crontab:
#
# */5 * * * * cd $HOME; path/to/buildcron.sh darwin 386 >/dev/null 2>/dev/null
if [ $# != 2 ]; then
echo 'usage: buildcron.sh goos goarch' 1>&2
exit 2
fi
export GOOS=$1
export GOARCH=$2
# Check if we are already running.
# First command must not be pipeline, to avoid seeing extra processes in ps.
all=$(ps axwwu)
pid=$(echo "$all" | grep "buildcron.sh $1 $2" | grep -v $$ | awk '{print $2}')
if [ "$pid" != "" ]; then
exit 0
fi
export BUILDHOST=godashboard.appspot.com
export BUILDER=${GOOS}-${GOARCH}
export GOROOT=$HOME/go-$BUILDER/go
export GOBIN=$HOME/go-$BUILDER/bin
if [ ! -f ~/.gobuildkey-$BUILDER ]; then
echo "need gobuildkey for $BUILDER in ~/.gobuildkey-$BUILDER" 1>&2
exit 2
fi
if [ ! -d $GOROOT ]; then
mkdir -p $GOROOT
hg clone https://go.googlecode.com/hg/ $GOROOT
fi
mkdir -p $GOROOT/bin
cd $GOROOT/..
cp go/misc/dashboard/builder.sh go/misc/dashboard/buildcontrol.py .
chmod a+x builder.sh buildcontrol.py
cd go
../buildcontrol.py next $BUILDER
cd ..
./builder.sh
...@@ -52,20 +52,28 @@ while true ; do ...@@ -52,20 +52,28 @@ while true ; do
mkdir -p candidate/bin || fatal "Cannot create candidate/bin" mkdir -p candidate/bin || fatal "Cannot create candidate/bin"
cd candidate/src || fatal "Cannot cd into candidate/src" cd candidate/src || fatal "Cannot cd into candidate/src"
echo "Building revision $rev" echo "Building revision $rev"
./all.bash > ../log 2>&1 ALL=all.bash
if [ -f all-$GOOS.bash ]; then
ALL=all-$GOOS.bash
elif [ -f all-$GOARCH.bash ]; then
ALL=all-$GOARCH.bash
fi
./$ALL > ../log 2>&1
if [ $? -ne 0 ] ; then if [ $? -ne 0 ] ; then
echo "Recording failure for $rev" echo "Recording failure for $rev"
python ../../buildcontrol.py record $BUILDER $rev ../log || fatal "Cannot record result" python ../../buildcontrol.py record $BUILDER $rev ../log || fatal "Cannot record result"
else else
echo "Recording success for $rev" echo "Recording success for $rev"
python ../../buildcontrol.py record $BUILDER $rev ok || fatal "Cannot record result" python ../../buildcontrol.py record $BUILDER $rev ok || fatal "Cannot record result"
echo "Running benchmarks" if [ "$ALL" = "all.bash" ]; then
cd pkg || fatal "failed to cd to pkg" echo "Running benchmarks"
make bench > ../../benchmarks 2>&1 cd pkg || fatal "failed to cd to pkg"
if [ $? -eq 0 ] ; then make bench > ../../benchmarks 2>&1
python ../../../buildcontrol.py benchmarks $BUILDER $rev ../../benchmarks || fatal "Cannot record benchmarks" if [ $? -eq 0 ] ; then
python ../../../buildcontrol.py benchmarks $BUILDER $rev ../../benchmarks || fatal "Cannot record benchmarks"
fi
cd .. || fatal "failed to cd out of pkg"
fi fi
cd .. || fatal "failed to cd out of pkg"
fi fi
cd ../.. || fatal "Cannot cd up" cd ../.. || fatal "Cannot cd up"
done done
...@@ -62,13 +62,15 @@ class Log(db.Model): ...@@ -62,13 +62,15 @@ class Log(db.Model):
class Highwater(db.Model): class Highwater(db.Model):
commit = db.StringProperty() commit = db.StringProperty()
N = 30
class MainPage(webapp.RequestHandler): class MainPage(webapp.RequestHandler):
def get(self): def get(self):
self.response.headers['Content-Type'] = 'text/html; charset=utf-8' self.response.headers['Content-Type'] = 'text/html; charset=utf-8'
q = Commit.all() q = Commit.all()
q.order('-__key__') q.order('-__key__')
results = q.fetch(30) results = q.fetch(N)
revs = [toRev(r) for r in results] revs = [toRev(r) for r in results]
builders = {} builders = {}
...@@ -104,17 +106,29 @@ class GetHighwater(webapp.RequestHandler): ...@@ -104,17 +106,29 @@ class GetHighwater(webapp.RequestHandler):
hw = Highwater.get_by_key_name('hw-%s' % builder) hw = Highwater.get_by_key_name('hw-%s' % builder)
if hw is None: if hw is None:
# If no highwater has been recorded for this builder, we find the # If no highwater has been recorded for this builder,
# initial commit and return that. # we go back N+1 commits and return that.
q = Commit.all() q = Commit.all()
q.filter('num =', 0) q.order('-__key__')
commitzero = q.get() c = q.fetch(N+1)[-1]
self.response.set_status(200) self.response.set_status(200)
self.response.out.write(commitzero.node) self.response.out.write(c.node)
return return
# if the proposed hw is too old, bump it forward
node = hw.commit
found = False
q = Commit.all()
q.order('-__key__')
recent = q.fetch(N+1)
for c in recent:
if c.node == node:
found = True
break
if not found:
node = recent[-1].node
self.response.set_status(200) self.response.set_status(200)
self.response.out.write(hw.commit) self.response.out.write(node)
def auth(req): def auth(req):
k = req.get('key') k = req.get('key')
...@@ -134,6 +148,18 @@ class SetHighwater(webapp.RequestHandler): ...@@ -134,6 +148,18 @@ class SetHighwater(webapp.RequestHandler):
if c is None: if c is None:
self.response.set_status(404) self.response.set_status(404)
return return
# if the proposed hw is too old, bump it forward
found = False
q = Commit.all()
q.order('-__key__')
recent = q.fetch(N+1)
for c in head:
if c.node == newhw:
found = True
break
if not found:
c = recent[-1]
hw = Highwater(key_name = 'hw-%s' % builder) hw = Highwater(key_name = 'hw-%s' % builder)
hw.commit = c.node hw.commit = c.node
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment