Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
go
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
go
Commits
2ce13ba4
Commit
2ce13ba4
authored
Jan 27, 2010
by
Russ Cox
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dashboard: builder tweaks
R=agl1 CC=golang-dev
https://golang.org/cl/194116
parent
424f9ca6
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
108 additions
and
17 deletions
+108
-17
misc/dashboard/README
misc/dashboard/README
+5
-1
misc/dashboard/buildcontrol.py
misc/dashboard/buildcontrol.py
+2
-2
misc/dashboard/buildcron.sh
misc/dashboard/buildcron.sh
+53
-0
misc/dashboard/builder.sh
misc/dashboard/builder.sh
+15
-7
misc/dashboard/godashboard/gobuild.py
misc/dashboard/godashboard/gobuild.py
+33
-7
No files found.
misc/dashboard/README
View file @
2ce13ba4
...
@@ -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:
...
...
misc/dashboard/buildcontrol.py
View file @
2ce13ba4
...
@@ -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'
:
...
...
misc/dashboard/buildcron.sh
0 → 100644
View file @
2ce13ba4
#!/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
misc/dashboard/builder.sh
View file @
2ce13ba4
...
@@ -52,13 +52,20 @@ while true ; do
...
@@ -52,13 +52,20 @@ 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"
if
[
"
$ALL
"
=
"all.bash"
]
;
then
echo
"Running benchmarks"
echo
"Running benchmarks"
cd
pkg
||
fatal
"failed to cd to pkg"
cd
pkg
||
fatal
"failed to cd to pkg"
make bench
>
../../benchmarks 2>&1
make bench
>
../../benchmarks 2>&1
...
@@ -67,5 +74,6 @@ while true ; do
...
@@ -67,5 +74,6 @@ while true ; do
fi
fi
cd
..
||
fatal
"failed to cd out of pkg"
cd
..
||
fatal
"failed to cd out of pkg"
fi
fi
fi
cd
../..
||
fatal
"Cannot cd up"
cd
../..
||
fatal
"Cannot cd up"
done
done
misc/dashboard/godashboard/gobuild.py
View file @
2ce13ba4
...
@@ -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__'
)
c
ommitzero
=
q
.
get
()
c
=
q
.
fetch
(
N
+
1
)[
-
1
]
self
.
response
.
set_status
(
200
)
self
.
response
.
set_status
(
200
)
self
.
response
.
out
.
write
(
c
ommitzero
.
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'
)
...
@@ -135,6 +149,18 @@ class SetHighwater(webapp.RequestHandler):
...
@@ -135,6 +149,18 @@ class SetHighwater(webapp.RequestHandler):
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
hw
.
put
()
hw
.
put
()
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment