Use xcrun to find path to make for Mac port
[WebKit-https.git] / Tools / TestResultServer / generate_builders_json.py
1 #!/usr/bin/env python
2 # Copyright (C) 2011 Google Inc. All rights reserved.
3 #
4 # Redistribution and use in source and binary forms, with or without
5 # modification, are permitted provided that the following conditions are
6 # met:
7 #
8 #     * Redistributions of source code must retain the above copyright
9 # notice, this list of conditions and the following disclaimer.
10 #     * Redistributions in binary form must reproduce the above
11 # copyright notice, this list of conditions and the following disclaimer
12 # in the documentation and/or other materials provided with the
13 # distribution.
14 #     * Neither the name of Google Inc. nor the names of its
15 # contributors may be used to endorse or promote products derived from
16 # this software without specific prior written permission.
17 #
18 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
21 # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
22 # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29
30 import json
31 import logging
32 import optparse
33 import os
34 import urllib2
35
36 # FIXME: See if Tools/Scripts/webkitpy/layout_tests/port/builders.py should also read
37 # the output json file here as its data source.
38
39
40 def master_json_url(master_url):
41     return master_url + '/json/builders'
42
43
44 def builder_json_url(master_url, builder):
45     return master_json_url(master_url) + '/' + urllib2.quote(builder)
46
47
48 def cached_build_json_url(master_url, builder, build_number):
49     return builder_json_url(master_url, builder) + '/builds/' + str(build_number)
50
51
52 def fetch_json(url):
53     logging.debug('Fetching %s' % url)
54     return json.load(urllib2.urlopen(url))
55
56
57 def insert_builder_and_test_data(masters):
58     for master in masters:
59         master_url = master['url']
60         tests_object = {}
61         master['tests'] = tests_object
62
63         for builder in fetch_json(master_json_url(master_url)):
64             build_data = fetch_json(builder_json_url(master_url, builder))
65             cached_builds = build_data['cachedBuilds']
66             current_builds = build_data['currentBuilds']
67
68             latest_cached_build = cached_builds.pop()
69             while latest_cached_build in current_builds and len(cached_builds):
70                 latest_cached_build = cached_builds.pop()
71
72             for step in fetch_json(cached_build_json_url(master_url, builder, latest_cached_build))['steps']:
73                 step_name = step['name']
74
75                 # The chromium bots call this step webkit-tests, the webkit.org bots call it layout-test. :(
76                 # The files stored at test-results.appspot.com use layout-tests as the test suite name, so normalize to that.
77                 if step_name in ['layout-test', 'webkit_tests']:
78                     step_name = 'layout-tests'
79
80                 is_test = step_name == 'layout-tests' if master['name'] == 'webkit.org' else 'test' in step_name and 'archive' not in step_name
81                 if not is_test:
82                     continue
83
84                 if step_name not in tests_object:
85                     tests_object[step_name] = {'builders': []}
86                 tests_object[step_name]['builders'].append(builder)
87
88     for step_name in tests_object:
89         tests_object[step_name]['builders'].sort()
90
91
92 def main():
93     option_parser = optparse.OptionParser()
94     option_parser.add_option('-v', '--verbose', action='store_true', default=False, help='Print debug logging')
95     options, args = option_parser.parse_args()
96
97     logging.getLogger().setLevel(logging.DEBUG if options.verbose else logging.INFO)
98
99     masters = [
100         {'name': 'ChromiumWin', 'url': 'http://build.chromium.org/p/chromium.win'},
101         {'name': 'ChromiumMac', 'url': 'http://build.chromium.org/p/chromium.mac'},
102         {'name': 'ChromiumLinux', 'url': 'http://build.chromium.org/p/chromium.linux'},
103         {'name': 'ChromiumChromiumOS', 'url': 'http://build.chromium.org/p/chromium.chromiumos'},
104         {'name': 'ChromiumGPU', 'url': 'http://build.chromium.org/p/chromium.gpu'},
105         {'name': 'ChromiumGPUFYI', 'url': 'http://build.chromium.org/p/chromium.gpu.fyi'},
106         {'name': 'ChromiumPerfAv', 'url': 'http://build.chromium.org/p/chromium.perf_av'},
107         {'name': 'ChromiumWebkit', 'url': 'http://build.chromium.org/p/chromium.webkit'},
108         {'name': 'webkit.org', 'url': 'http://build.webkit.org'},
109     ]
110
111     insert_builder_and_test_data(masters)
112
113     json_file_prefix = ('// This file is auto-generated by Tools/TestResultServer/generate_builders_json.py. It should not be manually modified.\n'
114         '// It uses jsonp instead of proper json because we want to be able to load it from a file URL in Chrome for local testing.\n'
115         'LOAD_BUILDBOT_DATA(')
116     json_file_suffix = ');\n';
117
118     json_file = open(os.path.join('static-dashboards', 'builders.jsonp'), 'w')
119     json_file.write(json_file_prefix + json.dumps(masters, separators=(', ', ': '), indent=4, sort_keys=True) + json_file_suffix)
120
121
122 if __name__ == "__main__":
123     main()