blob: 6c39c3a698428e98e53c81333c8c18a98c6654ec [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
45# gale armv7 3.18
46# kevin armv7 gru rockchip-3399 4.4.79
47# lakitu x86_64 4.4.79
48# link x86_64 ivybridge ivybridge 3.8.11
49# lumpy x86_64 -- sandybridge 3.8.11
50# nyan_big armv7 nyan tegra 3.10.18
51# peach_pit armv7 peach exynos-5420 3.8.11
52# peppy x86_64 slippy haswell 3.8.11
Manoj Guptaac5072d2017-09-29 10:51:20 -070053# pyro x86_64 reef apollo lake 4.4.79
Caroline Tice09cacd02017-08-11 13:02:29 -070054# sentry x86_64 kunimitsu skylake-u 3.18
Manoj Guptaac5072d2017-09-29 10:51:20 -070055# swanky x86_64 rambi baytrail 4.4.79
Caroline Tice09cacd02017-08-11 13:02:29 -070056# terra x86_64 strago braswell 3.18
57# whirlwind armv7 3.14
58
Yunlian Jiangc5713372016-06-15 11:37:50 -070059TEST_BOARD = [
Caroline Tice09cacd02017-08-11 13:02:29 -070060 'caroline',
61 'daisy',
62 'eve',
63 'gale',
64 'kevin',
Caroline Tice856bc6c2017-06-29 16:21:43 -070065 'lakitu',
Caroline Tice09cacd02017-08-11 13:02:29 -070066 'link',
67 'lumpy',
68 'nyan_big',
69 'peach_pit',
70 'peppy',
Manoj Guptaac5072d2017-09-29 10:51:20 -070071 'pyro',
Caroline Tice09cacd02017-08-11 13:02:29 -070072 'sentry',
Manoj Guptaac5072d2017-09-29 10:51:20 -070073 'swanky',
Caroline Tice09cacd02017-08-11 13:02:29 -070074 'terra',
Caroline Tice856bc6c2017-06-29 16:21:43 -070075 'whirlwind',
Caroline Ticea12e9742016-09-08 13:35:02 -070076]
77
Yunlian Jiangc5713372016-06-15 11:37:50 -070078
79class ToolchainVerifier(object):
80 """Class for the toolchain verifier."""
81
Caroline Ticea12e9742016-09-08 13:35:02 -070082 def __init__(self, board, chromeos_root, weekday, patches, compiler):
Yunlian Jiangc5713372016-06-15 11:37:50 -070083 self._board = board
84 self._chromeos_root = chromeos_root
85 self._base_dir = os.getcwd()
86 self._ce = command_executer.GetCommandExecuter()
87 self._l = logger.GetLogger()
Caroline Tice314ea562016-06-24 15:59:01 -070088 self._compiler = compiler
Yunlian Jiangbddbcd32017-11-27 10:59:30 -080089 self._build = '%s-%s-toolchain-tryjob' % (board, compiler)
Caroline Ticede600772016-10-18 15:27:51 -070090 self._patches = patches.split(',') if patches else []
Yunlian Jiangc5713372016-06-15 11:37:50 -070091 self._patches_string = '_'.join(str(p) for p in self._patches)
92
93 if not weekday:
94 self._weekday = time.strftime('%a')
95 else:
96 self._weekday = weekday
Caroline Ticed00ad412016-07-02 18:00:18 -070097 self._reports = os.path.join(VALIDATION_RESULT_DIR, compiler, board)
Yunlian Jiangc5713372016-06-15 11:37:50 -070098
99 def _FinishSetup(self):
100 """Make sure testing_rsa file is properly set up."""
101 # Fix protections on ssh key
102 command = ('chmod 600 /var/cache/chromeos-cache/distfiles/target'
103 '/chrome-src-internal/src/third_party/chromite/ssh_keys'
104 '/testing_rsa')
105 ret_val = self._ce.ChrootRunCommand(self._chromeos_root, command)
106 if ret_val != 0:
107 raise RuntimeError('chmod for testing_rsa failed')
108
Caroline Tice9c4003a2017-11-07 16:37:33 -0800109 def DoAll(self, crostc_dir):
Yunlian Jiangc5713372016-06-15 11:37:50 -0700110 """Main function inside ToolchainComparator class.
111
112 Launch trybot, get image names, create crosperf experiment file, run
113 crosperf, and copy images into seven-day report directories.
114 """
115 date_str = datetime.date.today()
116 description = 'master_%s_%s_%s' % (self._patches_string, self._build,
117 date_str)
Caroline Tice9c4003a2017-11-07 16:37:33 -0800118 if crostc_dir:
119 _ = buildbot_utils.GetTrybotImage(
120 self._chromeos_root,
121 self._build,
122 self._patches,
123 description,
124 tryjob_flags=['--hwtest'],
125 credentials_dir=crostc_dir,
126 async=True)
127 else:
128 _ = buildbot_utils.GetTrybotImage(
129 self._chromeos_root,
130 self._build,
131 self._patches,
132 description,
133 tryjob_flags=['--hwtest'],
134 async=True)
Yunlian Jiangc5713372016-06-15 11:37:50 -0700135
Yunlian Jiangc5713372016-06-15 11:37:50 -0700136 return 0
137
Manoj Guptad575b8a2017-03-08 10:51:28 -0800138
Yunlian Jiangc5713372016-06-15 11:37:50 -0700139def Main(argv):
140 """The main function."""
141
142 # Common initializations
143 command_executer.InitCommandExecuter()
144 parser = argparse.ArgumentParser()
Caroline Ticea12e9742016-09-08 13:35:02 -0700145 parser.add_argument(
146 '--chromeos_root',
147 dest='chromeos_root',
148 help='The chromeos root from which to run tests.')
149 parser.add_argument(
150 '--weekday',
151 default='',
152 dest='weekday',
153 help='The day of the week for which to run tests.')
154 parser.add_argument(
155 '--board', default='', dest='board', help='The board to test.')
156 parser.add_argument(
157 '--patch',
158 dest='patches',
Caroline Ticede600772016-10-18 15:27:51 -0700159 default='',
Caroline Ticea12e9742016-09-08 13:35:02 -0700160 help='The patches to use for the testing, '
161 "seprate the patch numbers with ',' "
162 'for more than one patches.')
163 parser.add_argument(
164 '--compiler',
165 dest='compiler',
Caroline Tice4bd70462016-10-05 15:41:13 -0700166 help='Which compiler (llvm, llvm-next or gcc) to use for '
Caroline Ticea12e9742016-09-08 13:35:02 -0700167 'testing.')
Caroline Tice9c4003a2017-11-07 16:37:33 -0800168 parser.add_argument(
169 '--crostc_dir',
170 dest='crostc_dir',
171 help='Path to the directory containing the '
172 'chromeos-toolchain-credentials.json file; normally in the '
173 'crostc repo.')
Yunlian Jiangc5713372016-06-15 11:37:50 -0700174
175 options = parser.parse_args(argv[1:])
176 if not options.chromeos_root:
177 print('Please specify the ChromeOS root directory.')
178 return 1
Caroline Tice314ea562016-06-24 15:59:01 -0700179 if not options.compiler:
Caroline Tice4bd70462016-10-05 15:41:13 -0700180 print('Please specify which compiler to test (gcc, llvm, or llvm-next).')
Caroline Tice314ea562016-06-24 15:59:01 -0700181 return 1
Yunlian Jiangc5713372016-06-15 11:37:50 -0700182
183 if options.board:
184 fv = ToolchainVerifier(options.board, options.chromeos_root,
Manoj Guptad575b8a2017-03-08 10:51:28 -0800185 options.weekday, options.patches, options.compiler)
Yunlian Jiangc5713372016-06-15 11:37:50 -0700186 return fv.Doall()
187
188 today = datetime.date.today()
189 delta = today - START_DATE
190 days = delta.days
191
192 start_board = (days * TEST_PER_DAY) % len(TEST_BOARD)
193 for i in range(TEST_PER_DAY):
Yunlian Jiang54e72b32016-06-21 14:13:03 -0700194 try:
Caroline Ticea12e9742016-09-08 13:35:02 -0700195 board = TEST_BOARD[(start_board + i) % len(TEST_BOARD)]
196 fv = ToolchainVerifier(board, options.chromeos_root, options.weekday,
Manoj Gupta86fe1ed2017-03-09 10:37:35 -0800197 options.patches, options.compiler)
Caroline Tice9c4003a2017-11-07 16:37:33 -0800198 fv.DoAll(options.crostc_dir)
Yunlian Jiang54e72b32016-06-21 14:13:03 -0700199 except SystemExit:
Caroline Ticed00ad412016-07-02 18:00:18 -0700200 logfile = os.path.join(VALIDATION_RESULT_DIR, options.compiler, board)
Yunlian Jiang54e72b32016-06-21 14:13:03 -0700201 with open(logfile, 'w') as f:
Caroline Ticea12e9742016-09-08 13:35:02 -0700202 f.write('Verifier got an exception, please check the log.\n')
Yunlian Jiangc5713372016-06-15 11:37:50 -0700203
Caroline Ticea12e9742016-09-08 13:35:02 -0700204
Yunlian Jiangc5713372016-06-15 11:37:50 -0700205if __name__ == '__main__':
206 retval = Main(sys.argv)
207 sys.exit(retval)