2012-02-01 11:59:23 +01:00
|
|
|
#!/usr/bin/env python
|
|
|
|
#-*- coding: utf-8 -*-
|
|
|
|
# Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
|
|
|
|
#
|
|
|
|
# Use of this source code is governed by a BSD-style license
|
|
|
|
# that can be found in the LICENSE file in the root of the source
|
|
|
|
# tree. An additional intellectual property rights grant can be found
|
|
|
|
# in the file PATENTS. All contributing project authors may
|
|
|
|
# be found in the AUTHORS file in the root of the source tree.
|
|
|
|
|
|
|
|
"""This script checks the current build status on the master and submits
|
|
|
|
it to the dashboard. It is adapted to build bot version 0.7.12.
|
|
|
|
"""
|
|
|
|
|
|
|
|
import httplib
|
|
|
|
|
|
|
|
import constants
|
|
|
|
import dashboard_connection
|
2012-02-01 18:08:03 +01:00
|
|
|
import tgrid_parser
|
2012-02-01 11:59:23 +01:00
|
|
|
|
2012-08-15 13:03:29 +02:00
|
|
|
# Bots that must be green in order to increment the LKGR revision.
|
2013-01-04 11:30:54 +01:00
|
|
|
BOTS = ['Win32 Debug',
|
|
|
|
'Win32 Release',
|
|
|
|
'Mac32 Debug',
|
|
|
|
'Mac32 Release',
|
|
|
|
'Linux32 Debug',
|
|
|
|
'Linux32 Release',
|
|
|
|
'Linux64 Debug',
|
|
|
|
'Linux64 Release',
|
|
|
|
'Linux Clang',
|
|
|
|
'Linux64 Debug GCC4.6',
|
|
|
|
'Linux Memcheck',
|
|
|
|
'Linux Tsan',
|
|
|
|
'Linux Asan',
|
|
|
|
'Win Large Tests',
|
|
|
|
'Mac Large Tests',
|
|
|
|
'Linux Large Tests',
|
2012-07-09 11:43:30 +02:00
|
|
|
'CrOS',
|
|
|
|
'Android',
|
2013-01-04 11:30:54 +01:00
|
|
|
'Android NDK',
|
2012-07-09 11:43:30 +02:00
|
|
|
]
|
|
|
|
|
|
|
|
|
2012-02-01 11:59:23 +01:00
|
|
|
class FailedToGetStatusFromMaster(Exception):
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
def _download_and_parse_build_status():
|
|
|
|
connection = httplib.HTTPConnection(constants.BUILD_MASTER_SERVER)
|
2012-02-01 18:08:03 +01:00
|
|
|
connection.request('GET', constants.BUILD_MASTER_TRANSPOSED_GRID_URL)
|
2012-02-01 11:59:23 +01:00
|
|
|
response = connection.getresponse()
|
|
|
|
|
|
|
|
if response.status != 200:
|
|
|
|
raise FailedToGetStatusFromMaster(('Failed to get build status from master:'
|
|
|
|
' got status %d, reason %s.' %
|
|
|
|
(response.status, response.reason)))
|
|
|
|
|
|
|
|
full_response = response.read()
|
|
|
|
connection.close()
|
|
|
|
|
2012-02-01 18:08:03 +01:00
|
|
|
return tgrid_parser.parse_tgrid_page(full_response)
|
2012-02-01 11:59:23 +01:00
|
|
|
|
|
|
|
|
2012-04-17 13:23:35 +02:00
|
|
|
def _is_chrome_only_build(revision_to_bot_name):
|
|
|
|
"""Figures out if a revision-to-bot-name mapping represents a Chrome build.
|
|
|
|
|
2012-07-09 11:43:30 +02:00
|
|
|
We assume here that Chrome revisions are always > 100000, whereas WebRTC
|
|
|
|
revisions will not reach that number in the foreseeable future.
|
|
|
|
"""
|
2012-04-17 13:23:35 +02:00
|
|
|
revision = int(revision_to_bot_name.split('--')[0])
|
|
|
|
bot_name = revision_to_bot_name.split('--')[1]
|
2012-05-11 13:34:29 +02:00
|
|
|
return 'Chrome' in bot_name and revision > 100000
|
2012-04-17 13:23:35 +02:00
|
|
|
|
|
|
|
|
2012-08-15 13:03:29 +02:00
|
|
|
def _filter_undesired_bots(bot_to_status_mapping, desired_bot_names):
|
2012-07-09 11:43:30 +02:00
|
|
|
"""Returns the desired bots for the builds status from the dictionary.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
bot_to_status_mapping: Dictionary mapping bot name with revision to status.
|
|
|
|
desired_bot_names: List of bot names that will be the only bots returned in
|
|
|
|
the resulting dictionary.
|
|
|
|
Returns: A dictionary only containing the desired bots.
|
|
|
|
"""
|
|
|
|
result = {}
|
|
|
|
for revision_to_bot_name, status in bot_to_status_mapping.iteritems():
|
|
|
|
bot_name = revision_to_bot_name.split('--')[1]
|
|
|
|
if bot_name in desired_bot_names:
|
|
|
|
result[revision_to_bot_name] = status
|
|
|
|
return result
|
|
|
|
|
|
|
|
|
2012-04-17 13:23:35 +02:00
|
|
|
def _filter_chrome_only_builds(bot_to_status_mapping):
|
|
|
|
"""Filters chrome-only builds from the system so LKGR doesn't get confused."""
|
|
|
|
return dict((revision_to_bot_name, status)
|
|
|
|
for revision_to_bot_name, status
|
|
|
|
in bot_to_status_mapping.iteritems()
|
|
|
|
if not _is_chrome_only_build(revision_to_bot_name))
|
|
|
|
|
|
|
|
|
2012-02-01 11:59:23 +01:00
|
|
|
def _main():
|
|
|
|
dashboard = dashboard_connection.DashboardConnection(constants.CONSUMER_KEY)
|
|
|
|
dashboard.read_required_files(constants.CONSUMER_SECRET_FILE,
|
|
|
|
constants.ACCESS_TOKEN_FILE)
|
|
|
|
|
|
|
|
bot_to_status_mapping = _download_and_parse_build_status()
|
2012-08-15 13:03:29 +02:00
|
|
|
bot_to_status_mapping = _filter_undesired_bots(bot_to_status_mapping, BOTS)
|
2012-04-17 13:23:35 +02:00
|
|
|
bot_to_status_mapping = _filter_chrome_only_builds(bot_to_status_mapping)
|
2012-02-01 11:59:23 +01:00
|
|
|
|
2012-02-06 11:55:12 +01:00
|
|
|
dashboard.send_post_request(constants.ADD_BUILD_STATUS_DATA_URL,
|
|
|
|
bot_to_status_mapping)
|
2012-02-01 11:59:23 +01:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
_main()
|