Chromium Code Reviews| Index: build/android/pylib/utils/flakiness_dashboard_results_uploader.py |
| diff --git a/build/android/pylib/flakiness_dashboard_results_uploader.py b/build/android/pylib/utils/flakiness_dashboard_results_uploader.py |
| similarity index 64% |
| rename from build/android/pylib/flakiness_dashboard_results_uploader.py |
| rename to build/android/pylib/utils/flakiness_dashboard_results_uploader.py |
| index 900af4cc498e6a0588c436edf3318e05a722057e..4dd846cb6362470301ae7572997b54e269fe8a71 100644 |
| --- a/build/android/pylib/flakiness_dashboard_results_uploader.py |
| +++ b/build/android/pylib/utils/flakiness_dashboard_results_uploader.py |
| @@ -11,11 +11,16 @@ import subprocess |
| import sys |
| import tempfile |
| -sys.path.append(os.path.join(sys.path[0], '..', '..', 'third_party', |
| - 'WebKit', 'Tools', 'Scripts')) |
| +sys.path.append( |
| + os.path.abspath(os.path.join(os.path.dirname(__file__ ), |
| + os.pardir, os.pardir, os.pardir, os.pardir, |
| + 'third_party', 'WebKit', 'Tools', 'Scripts'))) |
| from webkitpy.common.system import executive, filesystem |
| from webkitpy.layout_tests.layout_package import json_results_generator |
| +#TODO(craigdh): pylib/utils/ should not depend on pylib/. |
| +from pylib import constants |
| + |
| # The JSONResultsGenerator gets the filesystem.join operation from the Port |
| # object. Creating a Port object requires specifying information that only |
| @@ -56,21 +61,53 @@ class JSONResultsGenerator(json_results_generator.JSONResultsGeneratorBase): |
| #override |
| def _get_svn_revision(self, in_directory): |
| - """Returns the git revision for the given directory. |
| + """Returns the git/svn revision for the given directory. |
| Args: |
| - in_directory: The directory where git is to be run. |
| + in_directory: The directory relative to src. |
| """ |
| - git_dir = self._filesystem.join(os.environ.get('CHROME_SRC'), |
| - in_directory, |
| - '.git') |
| - if self._filesystem.exists(git_dir): |
| - # Note: Not thread safe: http://bugs.python.org/issue2320 |
| - output = subprocess.Popen( |
| - ['git', '--git-dir=%s' % git_dir, 'show-ref', '--head', |
| - '--hash=10', 'HEAD'], |
| - stdout=subprocess.PIPE).communicate()[0].strip() |
| - return output |
| + def _is_git_directory(in_directory): |
| + """Returns true if the given directory is in a git repository. |
| + |
| + Args: |
| + in_directory: The directory path to be tested. |
| + """ |
| + if os.path.exists(os.path.join(in_directory, '.git')): |
| + return True |
| + parent = os.path.dirname(in_directory) |
| + if parent == constants.CHROME_DIR or parent == in_directory: |
| + return False |
| + return _is_git_directory(parent) |
| + |
| + def _get_git_revision(in_directory): |
| + """Returns the git hash tag for the given directory. |
| + |
| + Args: |
| + in_directory: The directory where git is to be run. |
| + """ |
| + command_line = ['git', 'log', '-1', '--pretty=format:%H'] |
| + output = subprocess.Popen(command_line, |
| + cwd=in_directory, |
| + stdout=subprocess.PIPE).communicate()[0] |
| + return output[0:40] |
|
Isaac (use chromium)
2013/01/15 00:03:07
nit: output.strip()?
|
| + |
| + in_directory = os.path.join(constants.CHROME_DIR, in_directory) |
| + |
| + if not os.path.exists(os.path.join(in_directory, '.svn')): |
| + if _is_git_directory(in_directory): |
| + return _get_git_revision(in_directory) |
| + else: |
| + return '' |
| + |
| + # Note: Not thread safe: http://bugs.python.org/issue2320 |
| + output = subprocess.Popen(['svn', 'info', '--xml'], |
| + cwd=in_directory, |
| + stdout=subprocess.PIPE).communicate()[0] |
| + try: |
| + dom = xml.dom.minidom.parseString(output) |
| + return dom.getElementsByTagName('entry')[0].getAttribute('revision') |
| + except xml.parsers.expat.ExpatError: |
| + return '' |
| return '' |
| @@ -80,16 +117,26 @@ class ResultsUploader(object): |
| self._build_number = os.environ.get('BUILDBOT_BUILDNUMBER') |
| self._builder_name = os.environ.get('BUILDBOT_BUILDERNAME') |
| self._tests_type = tests_type |
| - self._build_name = 'chromium-android' |
| - if not self._builder_name: |
| + if not self._build_number or not self._builder_name: |
| raise Exception('You should not be uploading tests results to the server' |
| 'from your local machine.') |
| - buildbot_branch = os.environ.get('BUILDBOT_BRANCH') |
| - if not buildbot_branch: |
| - buildbot_branch = 'master' |
| - self._master_name = '%s-%s' % (self._build_name, buildbot_branch) |
| + upstream = (tests_type != 'Chromium_Android_Instrumentation') |
| + if upstream: |
| + # TODO(frankf): Use factory properties (see buildbot/bb_device_steps.py) |
| + # This requires passing the actual master name (e.g. 'ChromiumFYI' not |
| + # 'chromium.fyi'). |
| + from slave import slave_utils |
| + self._build_name = slave_utils.SlaveBuildName(constants.CHROME_DIR) |
| + self._master_name = slave_utils.GetActiveMaster() |
| + else: |
| + self._build_name = 'chromium-android' |
| + buildbot_branch = os.environ.get('BUILDBOT_BRANCH') |
| + if not buildbot_branch: |
| + buildbot_branch = 'master' |
| + self._master_name = '%s-%s' % (self._build_name, buildbot_branch) |
| + |
| self._test_results_map = {} |
| def AddResults(self, test_results): |