Currently, we store the configs for sanitizer bots in a separate repository:
https://code.google.com/p/address-sanitizer/source/browse/#svn%2Ftrunk%2Fbuild%2Fscripts%2Fslave
We are planing to add more hardware to the bots, and before that we would like to
perform some cleanup.
First (this change) we want to move the config files from the external repo to zorg.
Next, we'd like to change zorg/buildbot/builders/SanitizerBuilder.py to use the configs
from zorg instead of the extarnal repo.
Then we'll add some new bots.
Details
Diff Detail
Event Timeline
Hi Kostya, thanks for adding these. I haven't reviewed the code yet, but I
fully support this change!
Cheers,
Renato
Hi gkistanova, samsonov, eugenis,
Currently, we store the configs for sanitizer bots in a separate repository:
https://code.google.com/p/address-sanitizer/source/browse/#svn%2Ftrunk%2Fbuild%2Fscripts%2Fslave
We are planing to add more hardware to the bots, and before that we would
like to
perform some cleanup.
First (this change) we want to move the config files from the external repo
to zorg.
Next, we'd like to change zorg/buildbot/builders/SanitizerBuilder.py to use
the configs
from zorg instead of the extarnal repo.
Then we'll add some new bots.
Files:
zorg/buildbot/builders/sanitizers/ zorg/buildbot/builders/sanitizers/buildbot_bootstrap.sh zorg/buildbot/builders/sanitizers/buildbot_chrome_asan.sh zorg/buildbot/builders/sanitizers/buildbot_chrome_tsan.sh zorg/buildbot/builders/sanitizers/buildbot_cmake.sh zorg/buildbot/builders/sanitizers/buildbot_functions.sh zorg/buildbot/builders/sanitizers/buildbot_perf_asan.sh zorg/buildbot/builders/sanitizers/buildbot_selector.py zorg/buildbot/builders/sanitizers/buildbot_standard.bat zorg/buildbot/builders/sanitizers/buildbot_standard.sh zorg/buildbot/builders/sanitizers/slaveutil.py zorg/buildbot/builders/sanitizers/test_tsan.sh
llvm-commits mailing list
llvm-commits@cs.uiuc.edu
http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits
Kostya,
Stupid question, but did you have those scripts before Zorg had any builders? They seem completely disconnected with anything Zorg does. I was expecting a Builder class, like Buildbot docs describe...
cheers,
--renato
No, this is just a flexible way of writing buildbot scripts. Is not it easier to write a straightforward shell (or python, or any other language) script than muck with ShellCommand and friends?
The idea, and part of implementation, was stolen from the Chromium buildbot.
This seems like a reasonable place to put these scripts to me.
Yeah, see http://llvm.org/viewvc/llvm-project/zorg/trunk/zorg/buildbot/builders/SanitizerBuilder.py?view=markup . We would change that to point the svn checkout at zorg instead of some Google Code svn repo.
zorg/buildbot/builders/sanitizers/buildbot_chrome_asan.sh | ||
---|---|---|
1 ↗ | (On Diff #14191) | I doubt we need these *_chrome*.sh scripts. |
zorg/buildbot/builders/sanitizers/slaveutil.py | ||
1 ↗ | (On Diff #14191) | This file looks dead, even in the ASan repo. We probably don't need it. |
I should also mention that using these funky shell scripts in this way makes it possible for any committer to make changes the buildbot script and have it go live on the next build without waiting for a master restart.
remove 3 files from the change list
zorg/buildbot/builders/sanitizers/buildbot_chrome_asan.sh | ||
---|---|---|
1 ↗ | (On Diff #14191) | These bots (currently private) are using Chromium trunk to test LLVM trunk. |
zorg/buildbot/builders/sanitizers/slaveutil.py | ||
1 ↗ | (On Diff #14191) | removed |
I wanted this before, but I was sceptical to its value. I don't have a strong opinion about separating the scripts to make bot changes easier, but I'd prefer less bash and more python.
If the need to have bash is so it can work better at the shell level, than make the bash part the minimum necessary. Right now, you're duplicating a lot of the functionality on both shell and batch versions, things that the Builder library already does it better.
For example, we're in the process of unifying the repository checkout (svn, git, etc) for the ClangCMakeBuilder and this could be replicated across all other bots (since they all do the same thing), but with your current implementation you won't benefit from it and will increase the maintenance cost.
Also, please use:
#!/usr/bin/env bash
instead of:
#!/bin/bash
to make sure it'll work *everywhere*.
Is it possible to teach the common checkout code to update these
scripts as well? It should be easier now that they are in the same
repository.
For a full picture I'm missing of how these scripts are going to be used with the buildbot. Devil is in the details.
But I could wait with this till the second set of the patches.
The major questions are
- What build properties and parameters will be supported?
- How properties will be propagated through the buildbot infrastructure?
- If more than one script is used with one build, then the build seems to be a bit heavy. If there is only one script for a build, then I'd prefer seeing build steps instead of just one step with a heavy log to get a more granular and precise failure point from the bot. Something similar to what we did for the dragon egg with the scripted builder, perhaps?
These are the exact same scripts that are already used by the existing bots (e.g. lab.llvm.org:8011/builders/sanitizer-x86_64-linux),
but currently they are pulled from an external repo. see /zorg/buildbot/builders/SanitizerBuilder.py:
sanitizer_buildbot = "sanitizer_buildbot" # Get sanitizer buildbot scripts. f.addStep(SVN(name='svn-sanitizer-buildbot', mode='update', baseURL='http://address-sanitizer.googlecode.com/svn/', defaultBranch='trunk', workdir=sanitizer_buildbot, alwaysUseLatest=True)) sanitizer_script = os.path.join("..", sanitizer_buildbot, "build", "scripts", "slave", "buildbot_selector.py")
I am just moving them to zorg svn.
Once they are in zorg svn, we will modify SanitizerBuilder.py to not use the external repo any more.
The current structure: buildbot_selector.py selects which .sh script to invoke, one .sh script for the builder.
(I hope Alexey or Evgeniy can add some details to this)
I understand this.
The above questions are for when you will be changing the sanitizer builder.
I'd like to see those questions addressed then.
Looks good to me, assuming you will fix the scripts to reference to the shell on more generic way as Renato suggested.
Galina,
I'm not sure I'm answering the correct question, but: buildbot configuration for each builder is determined by buildbot_selector.py - it defines which shell script (and with which additional configuration options) should be run on each builder. This file should be updated for every new builder. Note, however, that in order to switch builder to a different configuration (or enable different set of flags there), it's enough to just commit a change to buildbot_selector.py, master restart will not be necessary.
Oh, regarding your question (3). The log for sanitizer builders is granular enough (see http://lab.llvm.org:8011/builders/sanitizer-x86_64-linux/builds/13223), thanks to AnnotatedFactory. We're running a single shell script, but it contains lines like
@@@BUILD_STEP check-asan@@@
which form separate cells in build log.
Changed /usr/bin/bash to "!/usr/bin/env bash"
and udated the scripts to their current version from
code.google.com/p/address-sanitizer
PTAL