Mercurial > mozilla > hg > talosnames
annotate talosnames/api.py @ 23:5f39ce13fbbc
what i meant
author | Jeff Hammel <jhammel@mozilla.com> |
---|---|
date | Tue, 10 Jul 2012 19:08:06 -0700 |
parents | 82d15f93cc4a |
children | c6a042aad739 |
rev | line source |
---|---|
12
a4aa9f83e3be
adding a thing for commands
Jeff Hammel <jhammel@mozilla.com>
parents:
10
diff
changeset
|
1 import os |
6 | 2 import re |
10 | 3 import require |
13
323a01abd180
putting off this fun for later
Jeff Hammel <jhammel@mozilla.com>
parents:
12
diff
changeset
|
4 import subprocess |
1 | 5 import sqlite3 |
12
a4aa9f83e3be
adding a thing for commands
Jeff Hammel <jhammel@mozilla.com>
parents:
10
diff
changeset
|
6 import sys |
13
323a01abd180
putting off this fun for later
Jeff Hammel <jhammel@mozilla.com>
parents:
12
diff
changeset
|
7 import talos |
16 | 8 import tempfile |
1 | 9 import urllib2 |
16 | 10 import yaml |
11 | |
12 try: | |
13 call = subprocess.check_call | |
14 except: | |
15 call = subprocess.call | |
1 | 16 |
13
323a01abd180
putting off this fun for later
Jeff Hammel <jhammel@mozilla.com>
parents:
12
diff
changeset
|
17 talos_dir = os.path.dirname(os.path.abspath(talos.__file__)) |
323a01abd180
putting off this fun for later
Jeff Hammel <jhammel@mozilla.com>
parents:
12
diff
changeset
|
18 |
12
a4aa9f83e3be
adding a thing for commands
Jeff Hammel <jhammel@mozilla.com>
parents:
10
diff
changeset
|
19 sys.path.insert(0, os.path.dirname(os.path.abspath(__file__))) |
a4aa9f83e3be
adding a thing for commands
Jeff Hammel <jhammel@mozilla.com>
parents:
10
diff
changeset
|
20 |
0 | 21 class TalosNames(object): |
22 graphserver_sql = 'http://hg.mozilla.org/graphs/raw-file/tip/sql/data.sql' | |
1 | 23 schema = 'http://hg.mozilla.org/graphs/raw-file/tip/sql/schema.sql' |
10 | 24 project_branches = 'http://hg.mozilla.org/build/buildbot-configs/raw-file/tip/mozilla/project_branches.py' |
25 buildbot_config = 'http://hg.mozilla.org/build/buildbot-configs/raw-file/tip/mozilla-tests/config.py' | |
1 | 26 |
5 | 27 # mapping file from builbot-configs name to tbpl codes: |
28 # http://hg.mozilla.org/users/mstange_themasta.com/tinderboxpushlog/file/tip/js/Config.js | |
6 | 29 tbpl_map = 'http://hg.mozilla.org/users/mstange_themasta.com/tinderboxpushlog/raw-file/tip/js/Data.js' |
5 | 30 |
2 | 31 tables = {'os_list': '(id, name text)', |
3 | 32 'branches': '(id, name text)', |
2 | 33 'machines': '(id, os_id int, is_throttling int, cpu_speed text, name text, is_active int, date_added int)', |
34 'pagesets': '(id, name text)', | |
35 'tests': '(id, name text, pretty_name text, is_chrome int, is_active int, pageset_id int)' | |
36 } | |
1 | 37 |
10 | 38 ### initialization functions |
39 | |
0 | 40 def __init__(self): |
5 | 41 self.setup_database() |
42 self.tbpl_mapping() | |
10 | 43 self.setup_buildbot() |
21 | 44 |
45 # cache | |
17
25e91fc7ff01
getting the test config now works
Jeff Hammel <jhammel@mozilla.com>
parents:
16
diff
changeset
|
46 self._talos_configs = {} |
21 | 47 self._tbpl_names = {} |
5 | 48 |
6 | 49 def setup_database(self): |
1 | 50 self.db = sqlite3.connect(':memory:') |
3 | 51 sql_lines = urllib2.urlopen(self.graphserver_sql).readlines() |
52 | |
53 # XXX remove the machines since they require a function, unix_timestamp(), sqlite does not have | |
54 sql_lines = [line for line in sql_lines | |
55 if 'unix_timestamp' not in line] | |
56 sql = '\n'.join(sql_lines) | |
57 | |
1 | 58 cursor = self.db.cursor() |
2 | 59 for table, schema in self.tables.items(): |
60 cursor.execute("""CREATE TABLE %s %s""" % (table, schema)) | |
3 | 61 cursor.executescript(sql) |
2 | 62 self.db.commit() |
63 cursor.close() | |
1 | 64 |
3 | 65 # create data structures |
66 self.names = {} | |
67 self.chrome = set() | |
68 cursor = self.db.cursor() | |
69 cursor.execute("SELECT * FROM tests") | |
70 for _, short_name, graphserver_name, is_chrome, _, _ in cursor.fetchall(): | |
71 self.names[short_name] = graphserver_name | |
72 if is_chrome: | |
73 self.chrome.add(short_name) | |
74 cursor.close() | |
75 | |
5 | 76 def tbpl_mapping(self): |
6 | 77 self.tbpl_regexs = {} |
78 lines = [line.strip() | |
79 for line in urllib2.urlopen(self.tbpl_map).readlines()] | |
80 lines = [line for line in lines | |
81 if line.startswith('/talos.*')] | |
82 regex = re.compile('\/talos\.\*(.*)\/.*\?.*\"([^"].*)\".*') | |
83 for line in lines: | |
84 match = regex.match(line) | |
85 assert match | |
86 _regex, name = match.groups() | |
87 self.tbpl_regexs[name] = _regex | |
5 | 88 |
10 | 89 def setup_buildbot(self): |
90 # project_branches = require.require(self.project_branches) | |
91 module = require.require(self.buildbot_config) | |
92 self.suites = module.SUITES | |
12
a4aa9f83e3be
adding a thing for commands
Jeff Hammel <jhammel@mozilla.com>
parents:
10
diff
changeset
|
93 self.buildbot_commands = {} |
a4aa9f83e3be
adding a thing for commands
Jeff Hammel <jhammel@mozilla.com>
parents:
10
diff
changeset
|
94 for key, value in self.suites.items(): |
a4aa9f83e3be
adding a thing for commands
Jeff Hammel <jhammel@mozilla.com>
parents:
10
diff
changeset
|
95 self.buildbot_commands[key] = value['suites'] |
10 | 96 |
97 ### functions for fetching information | |
98 | |
99 def tbpl_name(self, name): | |
100 """returns the TBPL long name""" | |
21 | 101 if name in self._tbpl_names: |
102 return self._tbpl_names[name] | |
10 | 103 for tbplname, regex in self.tbpl_regexs.items(): |
104 regex = re.compile(regex) | |
105 if regex.match(name): | |
21 | 106 self._tbpl_names[name] = tbplname |
10 | 107 return tbplname |
108 | |
12
a4aa9f83e3be
adding a thing for commands
Jeff Hammel <jhammel@mozilla.com>
parents:
10
diff
changeset
|
109 def buildbot_command(self, name): |
a4aa9f83e3be
adding a thing for commands
Jeff Hammel <jhammel@mozilla.com>
parents:
10
diff
changeset
|
110 """gets the buildbot command for a particular suite""" |
23 | 111 return self.buildbot_commands.get(name)[:] |
12
a4aa9f83e3be
adding a thing for commands
Jeff Hammel <jhammel@mozilla.com>
parents:
10
diff
changeset
|
112 |
14 | 113 def talos_config(self, name): |
114 """returns talos configuration for suite `name`""" | |
21 | 115 if name in self._talos_configs: |
116 return self._talos_configs[name] | |
117 | |
13
323a01abd180
putting off this fun for later
Jeff Hammel <jhammel@mozilla.com>
parents:
12
diff
changeset
|
118 command = self.buildbot_command(name) |
323a01abd180
putting off this fun for later
Jeff Hammel <jhammel@mozilla.com>
parents:
12
diff
changeset
|
119 assert command is not None, "Suite not found: %s" % name |
16 | 120 outfile = tempfile.mktemp(suffix='.yml') |
121 command += ['-o', outfile] # add an output file | |
122 command += ['-e', sys.executable] # add a pretend firefox so PerfConfigurator won't whine | |
123 call(['PerfConfigurator'] + command, stdout=subprocess.PIPE, cwd=talos_dir) | |
124 assert os.path.exists(outfile) | |
125 config = yaml.load(file(outfile)) | |
21 | 126 self._talos_configs[name] = config |
17
25e91fc7ff01
getting the test config now works
Jeff Hammel <jhammel@mozilla.com>
parents:
16
diff
changeset
|
127 return config |
25e91fc7ff01
getting the test config now works
Jeff Hammel <jhammel@mozilla.com>
parents:
16
diff
changeset
|
128 |
25e91fc7ff01
getting the test config now works
Jeff Hammel <jhammel@mozilla.com>
parents:
16
diff
changeset
|
129 def test_config(self, name): |
25e91fc7ff01
getting the test config now works
Jeff Hammel <jhammel@mozilla.com>
parents:
16
diff
changeset
|
130 test_config = self.talos_config(name)['tests'] |
25e91fc7ff01
getting the test config now works
Jeff Hammel <jhammel@mozilla.com>
parents:
16
diff
changeset
|
131 retval = {} |
25e91fc7ff01
getting the test config now works
Jeff Hammel <jhammel@mozilla.com>
parents:
16
diff
changeset
|
132 for test in test_config: |
25e91fc7ff01
getting the test config now works
Jeff Hammel <jhammel@mozilla.com>
parents:
16
diff
changeset
|
133 name = test.pop('name') |
25e91fc7ff01
getting the test config now works
Jeff Hammel <jhammel@mozilla.com>
parents:
16
diff
changeset
|
134 retval[name] = test |
25e91fc7ff01
getting the test config now works
Jeff Hammel <jhammel@mozilla.com>
parents:
16
diff
changeset
|
135 return retval |
13
323a01abd180
putting off this fun for later
Jeff Hammel <jhammel@mozilla.com>
parents:
12
diff
changeset
|
136 |
3 | 137 def __call__(self, name=None): |
138 retval = [] | |
139 for short_name, graphserver_name in self.names.items(): | |
140 if (name is None) or (name == short_name or short_name.startswith(name + '_')): | |
141 retval.append((short_name, graphserver_name)) | |
142 retval.sort(key=lambda x: x[0]) | |
143 return retval |