blob: 264a6d4f362e489ce4d0e04249c25c9aa53c76de [file] [log] [blame]
Caroline Tice4bd70462016-10-05 15:41:13 -07001#!/usr/bin/env python2
Ting-Yuan Huang4f59a622017-08-16 12:32:56 -07002#
3# Copyright 2017 The Chromium OS Authors. All rights reserved.
4# Use of this source code is governed by a BSD-style license that can be
5# found in the LICENSE file.
Yunlian Jiangc5713372016-06-15 11:37:50 -07006"""Script for running llvm validation tests on ChromeOS.
7
8This script launches a buildbot to build ChromeOS with the llvm on
9a particular board; then it finds and downloads the trybot image and the
10corresponding official image, and runs test for correctness.
11It then generates a report, emails it to the c-compiler-chrome, as
12well as copying the result into a directory.
13"""
14
15# Script to test different toolchains against ChromeOS benchmarks.
16
17from __future__ import print_function
18
19import argparse
20import datetime
21import os
22import sys
23import time
24
Caroline Ticea8af9a72016-07-20 12:52:59 -070025from cros_utils import command_executer
26from cros_utils import logger
Yunlian Jiangc5713372016-06-15 11:37:50 -070027
Caroline Ticea8af9a72016-07-20 12:52:59 -070028from cros_utils import buildbot_utils
Yunlian Jiangc5713372016-06-15 11:37:50 -070029
Yunlian Jiangc5713372016-06-15 11:37:50 -070030CROSTC_ROOT = '/usr/local/google/crostc'
31ROLE_ACCOUNT = 'mobiletc-prebuild'
32TOOLCHAIN_DIR = os.path.dirname(os.path.realpath(__file__))
33MAIL_PROGRAM = '~/var/bin/mail-sheriff'
34VALIDATION_RESULT_DIR = os.path.join(CROSTC_ROOT, 'validation_result')
35START_DATE = datetime.date(2016, 1, 1)
Manoj Gupta5ef88e52017-04-28 16:16:19 -070036TEST_PER_DAY = 3
Caroline Tice09cacd02017-08-11 13:02:29 -070037
38# Information about Rotating Boards
39# Board Arch Reference Platform Kernel
40# Board Version
41# -------- ------ --------- ---------- -------
42# caroline x86_64 glados skylake-y 3.18
43# daisy armv7 daisy exynos-5250 3.8.11
44# eve x86_64 poppy kabylake-y 4.4.79
Manoj Gupta470bbf52018-01-23 09:54:28 -080045# fizz x86_64 fizz kabylake-u/r 4.4
Caroline Tice09cacd02017-08-11 13:02:29 -070046# gale armv7 3.18
Manoj Guptafc7d1e62018-01-16 16:21:18 -080047# kahlee x86_64 kahlee stoney ridge 4.14
Caroline Tice09cacd02017-08-11 13:02:29 -070048# kevin armv7 gru rockchip-3399 4.4.79
49# lakitu x86_64 4.4.79
50# link x86_64 ivybridge ivybridge 3.8.11
51# lumpy x86_64 -- sandybridge 3.8.11
52# nyan_big armv7 nyan tegra 3.10.18
53# peach_pit armv7 peach exynos-5420 3.8.11
54# peppy x86_64 slippy haswell 3.8.11
Manoj Guptaac5072d2017-09-29 10:51:20 -070055# pyro x86_64 reef apollo lake 4.4.79
Caroline Tice09cacd02017-08-11 13:02:29 -070056# sentry x86_64 kunimitsu skylake-u 3.18
Manoj Guptaac5072d2017-09-29 10:51:20 -070057# swanky x86_64 rambi baytrail 4.4.79
Caroline Tice09cacd02017-08-11 13:02:29 -070058# terra x86_64 strago braswell 3.18
59# whirlwind armv7 3.14
Manoj Gupta470bbf52018-01-23 09:54:28 -080060# zoombini x86_64 zoombini cannonlake-y 4.14
Caroline Tice09cacd02017-08-11 13:02:29 -070061
Yunlian Jiangc5713372016-06-15 11:37:50 -070062TEST_BOARD = [
Caroline Tice09cacd02017-08-11 13:02:29 -070063 'caroline',
64 'daisy',
65 'eve',
Manoj Gupta470bbf52018-01-23 09:54:28 -080066 'fizz',
Caroline Tice09cacd02017-08-11 13:02:29 -070067 'gale',
Manoj Guptafc7d1e62018-01-16 16:21:18 -080068 'kahlee',
Caroline Tice09cacd02017-08-11 13:02:29 -070069 'kevin',
Caroline Tice856bc6c2017-06-29 16:21:43 -070070 'lakitu',
Caroline Tice09cacd02017-08-11 13:02:29 -070071 'link',
72 'lumpy',
73 'nyan_big',
74 'peach_pit',
75 'peppy',
Manoj Guptaac5072d2017-09-29 10:51:20 -070076 'pyro',
Caroline Tice09cacd02017-08-11 13:02:29 -070077 'sentry',
Manoj Guptaac5072d2017-09-29 10:51:20 -070078 'swanky',
Caroline Tice09cacd02017-08-11 13:02:29 -070079 'terra',
Caroline Tice856bc6c2017-06-29 16:21:43 -070080 'whirlwind',
Manoj Gupta470bbf52018-01-23 09:54:28 -080081 'zoombini',
Caroline Ticea12e9742016-09-08 13:35:02 -070082]
83
Yunlian Jiangc5713372016-06-15 11:37:50 -070084
85class ToolchainVerifier(object):
86 """Class for the toolchain verifier."""
87
Caroline Ticea12e9742016-09-08 13:35:02 -070088 def __init__(self, board, chromeos_root, weekday, patches, compiler):
Yunlian Jiangc5713372016-06-15 11:37:50 -070089 self._board = board
90 self._chromeos_root = chromeos_root
91 self._base_dir = os.getcwd()
92 self._ce = command_executer.GetCommandExecuter()
93 self._l = logger.GetLogger()
Caroline Tice314ea562016-06-24 15:59:01 -070094 self._compiler = compiler
Yunlian Jiangbddbcd32017-11-27 10:59:30 -080095 self._build = '%s-%s-toolchain-tryjob' % (board, compiler)
Caroline Ticede600772016-10-18 15:27:51 -070096 self._patches = patches.split(',') if patches else []
Yunlian Jiangc5713372016-06-15 11:37:50 -070097 self._patches_string = '_'.join(str(p) for p in self._patches)
98
99 if not weekday:
100 self._weekday = time.strftime('%a')
101 else:
102 self._weekday = weekday
Caroline Ticed00ad412016-07-02 18:00:18 -0700103 self._reports = os.path.join(VALIDATION_RESULT_DIR, compiler, board)
Yunlian Jiangc5713372016-06-15 11:37:50 -0700104
105 def _FinishSetup(self):
106 """Make sure testing_rsa file is properly set up."""
107 # Fix protections on ssh key
108 command = ('chmod 600 /var/cache/chromeos-cache/distfiles/target'
109 '/chrome-src-internal/src/third_party/chromite/ssh_keys'
110 '/testing_rsa')
111 ret_val = self._ce.ChrootRunCommand(self._chromeos_root, command)
112 if ret_val != 0:
113 raise RuntimeError('chmod for testing_rsa failed')
114
Caroline Tice9c4003a2017-11-07 16:37:33 -0800115 def DoAll(self, crostc_dir):
Yunlian Jiangc5713372016-06-15 11:37:50 -0700116 """Main function inside ToolchainComparator class.
117
118 Launch trybot, get image names, create crosperf experiment file, run
119 crosperf, and copy images into seven-day report directories.
120 """
121 date_str = datetime.date.today()
122 description = 'master_%s_%s_%s' % (self._patches_string, self._build,
123 date_str)
Caroline Tice9c4003a2017-11-07 16:37:33 -0800124 if crostc_dir:
125 _ = buildbot_utils.GetTrybotImage(
126 self._chromeos_root,
127 self._build,
128 self._patches,
129 description,
130 tryjob_flags=['--hwtest'],
131 credentials_dir=crostc_dir,
132 async=True)
133 else:
134 _ = buildbot_utils.GetTrybotImage(
135 self._chromeos_root,
136 self._build,
137 self._patches,
138 description,
139 tryjob_flags=['--hwtest'],
140 async=True)
Yunlian Jiangc5713372016-06-15 11:37:50 -0700141
Yunlian Jiangc5713372016-06-15 11:37:50 -0700142 return 0
143
Manoj Guptad575b8a2017-03-08 10:51:28 -0800144
Yunlian Jiangc5713372016-06-15 11:37:50 -0700145def Main(argv):
146 """The main function."""
147
148 # Common initializations
149 command_executer.InitCommandExecuter()
150 parser = argparse.ArgumentParser()
Caroline Ticea12e9742016-09-08 13:35:02 -0700151 parser.add_argument(
152 '--chromeos_root',
153 dest='chromeos_root',
154 help='The chromeos root from which to run tests.')
155 parser.add_argument(
156 '--weekday',
157 default='',
158 dest='weekday',
159 help='The day of the week for which to run tests.')
160 parser.add_argument(
161 '--board', default='', dest='board', help='The board to test.')
162 parser.add_argument(
163 '--patch',
164 dest='patches',
Caroline Ticede600772016-10-18 15:27:51 -0700165 default='',
Caroline Ticea12e9742016-09-08 13:35:02 -0700166 help='The patches to use for the testing, '
167 "seprate the patch numbers with ',' "
168 'for more than one patches.')
169 parser.add_argument(
170 '--compiler',
171 dest='compiler',
Caroline Tice4bd70462016-10-05 15:41:13 -0700172 help='Which compiler (llvm, llvm-next or gcc) to use for '
Caroline Ticea12e9742016-09-08 13:35:02 -0700173 'testing.')
Caroline Tice9c4003a2017-11-07 16:37:33 -0800174 parser.add_argument(
175 '--crostc_dir',
176 dest='crostc_dir',
177 help='Path to the directory containing the '
178 'chromeos-toolchain-credentials.json file; normally in the '
179 'crostc repo.')
Yunlian Jiangc5713372016-06-15 11:37:50 -0700180
181 options = parser.parse_args(argv[1:])
182 if not options.chromeos_root:
183 print('Please specify the ChromeOS root directory.')
184 return 1
Caroline Tice314ea562016-06-24 15:59:01 -0700185 if not options.compiler:
Caroline Tice4bd70462016-10-05 15:41:13 -0700186 print('Please specify which compiler to test (gcc, llvm, or llvm-next).')
Caroline Tice314ea562016-06-24 15:59:01 -0700187 return 1
Yunlian Jiangc5713372016-06-15 11:37:50 -0700188
189 if options.board:
190 fv = ToolchainVerifier(options.board, options.chromeos_root,
Manoj Guptad575b8a2017-03-08 10:51:28 -0800191 options.weekday, options.patches, options.compiler)
Yunlian Jiangc5713372016-06-15 11:37:50 -0700192 return fv.Doall()
193
194 today = datetime.date.today()
195 delta = today - START_DATE
196 days = delta.days
197
198 start_board = (days * TEST_PER_DAY) % len(TEST_BOARD)
199 for i in range(TEST_PER_DAY):
Yunlian Jiang54e72b32016-06-21 14:13:03 -0700200 try:
Caroline Ticea12e9742016-09-08 13:35:02 -0700201 board = TEST_BOARD[(start_board + i) % len(TEST_BOARD)]
202 fv = ToolchainVerifier(board, options.chromeos_root, options.weekday,
Manoj Gupta86fe1ed2017-03-09 10:37:35 -0800203 options.patches, options.compiler)
Caroline Tice9c4003a2017-11-07 16:37:33 -0800204 fv.DoAll(options.crostc_dir)
Yunlian Jiang54e72b32016-06-21 14:13:03 -0700205 except SystemExit:
Caroline Ticed00ad412016-07-02 18:00:18 -0700206 logfile = os.path.join(VALIDATION_RESULT_DIR, options.compiler, board)
Yunlian Jiang54e72b32016-06-21 14:13:03 -0700207 with open(logfile, 'w') as f:
Caroline Ticea12e9742016-09-08 13:35:02 -0700208 f.write('Verifier got an exception, please check the log.\n')
Yunlian Jiangc5713372016-06-15 11:37:50 -0700209
Caroline Ticea12e9742016-09-08 13:35:02 -0700210
Yunlian Jiangc5713372016-06-15 11:37:50 -0700211if __name__ == '__main__':
212 retval = Main(sys.argv)
213 sys.exit(retval)