Index: client/tools/buildbot_annotated_steps.py |
diff --git a/client/tools/buildbot_annotated_steps.py b/client/tools/buildbot_annotated_steps.py |
index 658e25c51c4374a089043e26bb6318dc197d2155..1ca39335a4fa180cb800b16b28eaf9fe20d7fb8b 100755 |
--- a/client/tools/buildbot_annotated_steps.py |
+++ b/client/tools/buildbot_annotated_steps.py |
@@ -9,8 +9,8 @@ |
"""Dart client buildbot steps |
-Compiles dart client apps with dartc, and run the client tests both in headless |
-chromium and headless dartium. |
+Calls a script in tools/bots whose name is based on the name of the bot. |
+ |
""" |
import imp |
@@ -22,101 +22,18 @@ import sys |
BUILDER_NAME = 'BUILDBOT_BUILDERNAME' |
BUILDER_CLOBBER = 'BUILDBOT_CLOBBER' |
-REVISION = 'BUILDBOT_REVISION' |
- |
-# latest dartium location |
-DARTIUM_VERSION_FILE = 'client/tests/drt/LAST_VERSION' |
-DARTIUM_V_MATCHER = ( |
- 'gs://dartium-archive/[^/]*/dartium-\w*-inc-([0-9]*).([0-9]*).zip') |
- |
-def GetUtils(): |
- '''Dynamically load the tools/utils.py python module.''' |
- dart_dir = os.path.abspath(os.path.join(__file__, '..', '..', '..')) |
- return imp.load_source('utils', os.path.join(dart_dir, 'tools', 'utils.py')) |
-utils = GetUtils() |
- |
-def GetBuildInfo(): |
- """Returns a tuple (name, version, mode) where: |
- - name: A name for the build - the buildbot host if a buildbot. |
- - version: A version string corresponding to this build. |
+def GetName(): |
+ """Returns the name of the bot. |
""" |
name = None |
- version = None |
- |
# Populate via builder environment variables. |
name = os.environ.get(BUILDER_NAME) |
- version = os.environ.get(REVISION) |
# Fall back if not on builder. |
if not name: |
name = socket.gethostname().split('.')[0] |
- if not version: |
- # In Windows we need to run in the shell, so that we have all the |
- # environment variables available. |
- pipe = subprocess.Popen( |
- ['svnversion', '-n'], stdout=subprocess.PIPE, stderr=subprocess.PIPE, |
- shell=True) |
- output = pipe.communicate() |
- if pipe.returncode == 0: |
- version = output[0] |
- else: |
- version = 'unknown' |
- return (name, version) |
- |
-def GetOutDir(mode): |
- ''' |
- get the location to place the output |
- |
- args: |
- utils - the tools/utils.py module |
- mode - the mode release or debug |
- ''' |
- return utils.GetBuildRoot(utils.GuessOS(), mode, utils.ARCH_GUESS) |
- |
-def ProcessTools(mode, name, version): |
- ''' |
- build and test the tools |
- |
- args: |
- srcpath - the location of the source code to build |
- mode - the mode release or debug |
- version - the svn version of the currently checked out code |
- ''' |
- print 'ProcessTools' |
- |
- toolsBuildScript = os.path.join('.', 'editor', 'build', 'build.py') |
- |
- build_installer = name.startswith('dart-editor-installer') |
- |
- # TODO(devoncarew): should we move this into GetBuildInfo()? |
- # get the latest changed revision from the current repository sub-tree |
- version = GetLatestChangedRevision() |
- |
- outdir = GetOutDir(mode) |
- cmds = [sys.executable, toolsBuildScript, |
- '--mode=' + mode, '--revision=' + version, |
- '--name=' + name, '--out=' + outdir] |
- if build_installer: |
- cmds.append('--build-installer') |
- local_env = EnvironmentWithoutBotoConfig() |
- #if 'linux' in name: |
- # javahome = os.path.join(os.path.expanduser('~'), 'jdk1.6.0_25') |
- # local_env['JAVA_HOME'] = javahome |
- # local_env['PATH'] = (os.path.join(javahome, 'bin') + |
- # os.pathsep + local_env['PATH']) |
- |
- return subprocess.call(cmds, env=local_env) |
- |
-def EnvironmentWithoutBotoConfig(environment=None): |
- # The buildbot sets AWS_CREDENTIAL_FILE/BOTO_CONFIG to the chromium specific |
- # file, we use the one in home. |
- custom_env = dict(environment or os.environ) |
- if 'BOTO_CONFIG' in custom_env: |
- del custom_env['BOTO_CONFIG'] |
- if 'AWS_CREDENTIAL_FILE' in custom_env: |
- del custom_env['AWS_CREDENTIAL_FILE'] |
- return custom_env |
+ return name |
def ProcessBot(name, target, custom_env=None): |
''' |
@@ -134,18 +51,6 @@ def ProcessBot(name, target, custom_env=None): |
os.path.join('tools', 'bots', target + '.py')], |
env=environment, shell=has_shell) |
-def FixJavaHome(): |
- buildbot_javahome = os.getenv('BUILDBOT_JAVA_HOME') |
- if buildbot_javahome: |
- current_pwd = os.getenv('PWD') |
- java_home = os.path.join(current_pwd, buildbot_javahome) |
- java_bin = os.path.join(java_home, 'bin') |
- os.environ['JAVA_HOME'] = java_home |
- os.environ['PATH'] = '%s;%s' % (java_bin, os.environ['PATH']) |
- |
- print 'Setting java home to ', java_home |
- sys.stdout.flush() |
- |
def ClobberBuilder(): |
""" Clobber the builder before we do the build. |
""" |
@@ -157,12 +62,6 @@ def ClobberBuilder(): |
def GetShouldClobber(): |
return os.environ.get(BUILDER_CLOBBER) == "1" |
-def GetLatestChangedRevision(): |
- revision = utils.GetSVNRevision() |
- if not revision: |
- raise Exception("Couldn't determine last changed revision.") |
- return revision |
- |
def main(): |
if len(sys.argv) == 0: |
print 'Script pathname not known, giving up.' |
@@ -179,12 +78,7 @@ def main(): |
print '@@@STEP_FAILURE@@@' |
return status |
- |
- #TODO(sigmund): remove this indirection once we update our bots |
- (name, version) = GetBuildInfo() |
- # The buildbot will set a BUILDBOT_JAVA_HOME relative to the dart |
- # root directory, set JAVA_HOME based on that. |
- FixJavaHome() |
+ name = GetName() |
if name.startswith('pub-'): |
status = ProcessBot(name, 'pub') |
elif name.startswith('vm-android'): |
@@ -192,8 +86,7 @@ def main(): |
elif name.startswith('dart-sdk'): |
status = ProcessBot(name, 'dart_sdk') |
elif name.startswith('cross') or name.startswith('target'): |
- status = ProcessBot(name, 'cross-vm', |
- custom_env=EnvironmentWithoutBotoConfig()) |
+ status = ProcessBot(name, 'cross-vm') |
elif name.startswith('linux-distribution-support'): |
status = ProcessBot(name, 'linux_distribution_support') |
elif name.startswith('version-checker'): |