Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(129)

Side by Side Diff: PRESUBMIT.py

Issue 1189583003: Move default trybots configuration to CQ config. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Caught up with recent Chromium PRESUBMIT.py changes Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | infra/config/cq.cfg » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 # Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. 1 # Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
2 # 2 #
3 # Use of this source code is governed by a BSD-style license 3 # Use of this source code is governed by a BSD-style license
4 # that can be found in the LICENSE file in the root of the source 4 # that can be found in the LICENSE file in the root of the source
5 # tree. An additional intellectual property rights grant can be found 5 # tree. An additional intellectual property rights grant can be found
6 # in the file PATENTS. All contributing project authors may 6 # in the file PATENTS. All contributing project authors may
7 # be found in the AUTHORS file in the root of the source tree. 7 # be found in the AUTHORS file in the root of the source tree.
8 8
9 import json
9 import os 10 import os
11 import platform
10 import re 12 import re
13 import subprocess
11 import sys 14 import sys
12 15
13 16
14 def _CheckNoIOStreamInHeaders(input_api, output_api): 17 def _CheckNoIOStreamInHeaders(input_api, output_api):
15 """Checks to make sure no .h files include <iostream>.""" 18 """Checks to make sure no .h files include <iostream>."""
16 files = [] 19 files = []
17 pattern = input_api.re.compile(r'^#include\s*<iostream>', 20 pattern = input_api.re.compile(r'^#include\s*<iostream>',
18 input_api.re.MULTILINE) 21 input_api.re.MULTILINE)
19 for f in input_api.AffectedSourceFiles(input_api.FilterSourceFile): 22 for f in input_api.AffectedSourceFiles(input_api.FilterSourceFile):
20 if not f.LocalPath().endswith('.h'): 23 if not f.LocalPath().endswith('.h'):
(...skipping 304 matching lines...) Expand 10 before | Expand all | Expand 10 after
325 results.extend(input_api.canned_checks.CheckChangeHasBugField( 328 results.extend(input_api.canned_checks.CheckChangeHasBugField(
326 input_api, output_api)) 329 input_api, output_api))
327 results.extend(input_api.canned_checks.CheckChangeHasTestField( 330 results.extend(input_api.canned_checks.CheckChangeHasTestField(
328 input_api, output_api)) 331 input_api, output_api))
329 results.extend(input_api.canned_checks.CheckTreeIsOpen( 332 results.extend(input_api.canned_checks.CheckTreeIsOpen(
330 input_api, output_api, 333 input_api, output_api,
331 json_url='http://webrtc-status.appspot.com/current?format=json')) 334 json_url='http://webrtc-status.appspot.com/current?format=json'))
332 return results 335 return results
333 336
334 337
335 def GetDefaultTryConfigs(bots=None):
336 """Returns a list of ('bot', set(['tests']), optionally filtered by [bots].
337
338 For WebRTC purposes, we always return an empty list of tests, since we want
339 to run all tests by default on all our trybots.
340 """
341 return {'tryserver.webrtc': dict((bot, []) for bot in bots)}
342
343
344 # pylint: disable=W0613 338 # pylint: disable=W0613
345 def GetPreferredTryMasters(project, change): 339 def GetPreferredTryMasters(project, change):
346 files = change.LocalPaths() 340 cq_config_path = os.path.join(
341 change.RepositoryRoot(), 'infra', 'config', 'cq.cfg')
342 # commit_queue.py below is a script in depot_tools directory, which has a
343 # 'builders' command to retrieve a list of CQ builders from the CQ config.
344 is_win = platform.system() == 'Windows'
345 masters = json.loads(subprocess.check_output(
346 ['commit_queue', 'builders', cq_config_path], shell=is_win))
347 347
348 android_gn_bots = [ 348 try_config = {}
349 'android_gn', 349 for master in masters:
350 'android_gn_rel', 350 try_config.setdefault(master, {})
351 ] 351 for builder in masters[master]:
352 android_bots = [ 352 # Do not trigger presubmit builders, since they're likely to fail
353 'android', 353 # (e.g. OWNERS checks before finished code review), and we're running
354 'android_arm64_rel', 354 # local presubmit anyway.
355 'android_rel', 355 if 'presubmit' not in builder:
phoglund 2015/06/16 10:11:31 I think this can be written clearer, like if 'pre
kjellander_webrtc 2015/06/16 10:59:49 Good idea; I implemented it in PS#4.
356 'android_clang', 356 try_config[master][builder] = ['defaulttests']
357 ] + android_gn_bots
358 ios_bots = [
359 'ios',
360 'ios_arm64',
361 'ios_arm64_rel',
362 'ios_rel',
363 'ios32_sim',
364 'ios64_sim',
365 ]
366 linux_gn_bots = [
367 'linux_gn',
368 'linux_gn_rel',
369 ]
370 linux_bots = [
371 'linux',
372 'linux_asan',
373 'linux_baremetal',
374 'linux_msan',
375 'linux_rel',
376 'linux_tsan2',
377 ] + linux_gn_bots
378 mac_gn_bots = [
379 'mac_x64_gn',
380 'mac_x64_gn_rel',
381 ]
382 mac_bots = [
383 'mac',
384 'mac_asan',
385 'mac_baremetal',
386 'mac_rel',
387 'mac_x64',
388 'mac_x64_rel',
389 ] + mac_gn_bots
390 win_gn_bots = [
391 'win_x64_gn',
392 'win_x64_gn_rel',
393 ]
394 win_bots = [
395 'win',
396 'win_baremetal',
397 'win_drmemory_light',
398 'win_rel',
399 'win_x64_rel',
400 ] + win_gn_bots
401 if not files or all(re.search(r'[\\/]OWNERS$', f) for f in files):
402 return {}
403 if all(re.search(r'[\\/]BUILD.gn$', f) for f in files):
404 return GetDefaultTryConfigs(android_gn_bots + linux_gn_bots + mac_gn_bots +
405 win_gn_bots)
406 if all(re.search('[/_]mac[/_.]', f) for f in files):
407 return GetDefaultTryConfigs(mac_bots)
408 if all(re.search('(^|[/_])win[/_.]', f) for f in files):
409 return GetDefaultTryConfigs(win_bots)
410 if all(re.search('(^|[/_])android[/_.]', f) for f in files):
411 return GetDefaultTryConfigs(android_bots)
412 if all(re.search('[/_]ios[/_.]', f) for f in files):
413 return GetDefaultTryConfigs(ios_bots)
414 357
415 return GetDefaultTryConfigs(android_bots + ios_bots + linux_bots + mac_bots + 358 return try_config
416 win_bots)
OLDNEW
« no previous file with comments | « no previous file | infra/config/cq.cfg » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698