blob: f05bb22416e0aa67d407b59b753f89309bc07391 [file] [log] [blame]
mtklein11a2c502015-02-24 09:25:16 -08001#!/usr/bin/env python
2
3usage = '''
4Write extra flags to outfile for DM based on the bot name:
5 $ python dm_flags.py outfile Test-Mac10.9-MacMini6.2-HD4000-x86_64-Release
6Or run self-tests:
7 $ python dm_flags.py test
8'''
9
10import inspect
11import json
12import os
13import sys
14
15
16def lineno():
17 caller = inspect.stack()[1] # Up one level to our caller.
18 return inspect.getframeinfo(caller[0]).lineno
19
20
21cov_start = lineno()+1 # We care about coverage starting just past this def.
mtkleinf73e5892015-02-24 11:45:11 -080022def get_args(bot):
mtklein11a2c502015-02-24 09:25:16 -080023 args = []
24
mtklein341c8082015-03-02 09:51:44 -080025 configs = ['565', '8888', 'gpu']
bsalomon5abf5842015-02-27 10:13:36 -080026 # The S4 crashes and the NP produces a long error stream when we run with
27 # MSAA.
28 if ('GalaxyS4' not in bot and
29 'NexusPlayer' not in bot):
30 if 'Android' in bot:
31 configs.extend(['msaa4', 'nvprmsaa4'])
32 else:
33 configs.extend(['msaa16', 'nvprmsaa16'])
mtklein82b33db2015-03-04 13:58:05 -080034 # Runs out of memory on Android bots and Daisy. Everyone else seems fine.
mtklein150d3502015-03-05 13:38:17 -080035 if 'Android' not in bot and 'Daisy' not in bot:
mtklein84aada82015-03-04 11:47:11 -080036 configs.append('pdf')
bsalomon5abf5842015-02-27 10:13:36 -080037
mtklein11a2c502015-02-24 09:25:16 -080038 # Xoom and NP are running out of RAM when we run all these modes. skia:3255
39 if ('Xoom' not in bot and
40 'NexusPlayer' not in bot):
41 configs.extend(mode + '-8888' for mode in
42 ['serialize', 'tiles_rt', 'pipe'])
43 configs.append('tiles_rt-gpu')
mtkleinee2a3ea2015-02-25 08:16:19 -080044 if 'ANGLE' in bot:
45 configs.append('angle')
mtklein11a2c502015-02-24 09:25:16 -080046 args.append('--config')
47 args.extend(configs)
48
49 blacklist = []
50 # This image is too large to be a texture for many GPUs.
51 blacklist.extend('gpu _ PANO_20121023_214540.jpg'.split(' '))
52 blacklist.extend('msaa _ PANO_20121023_214540.jpg'.split(' '))
53
mtkleine2aab902015-03-17 12:52:16 -070054 # Leon doesn't care about this, so why run it?
55 if 'Win' in bot:
56 blacklist.extend('_ image _'.split(' '))
57 blacklist.extend('_ subset _'.split(' '))
58
egdaniel89c2a542015-03-19 13:09:17 -070059 # Certain gm's on win7 gpu and pdf are never finishing and keeping the test
60 # running forever
61 if 'Win7' in bot:
62 blacklist.extend('msaa16 gm colorwheelnative'.split(' '))
63 blacklist.extend('pdf gm fontmgr_iter_factory'.split(' '))
64
mtklein11a2c502015-02-24 09:25:16 -080065 # Drawing SKPs or images into GPU canvases is a New Thing.
66 # It seems like we're running out of RAM on some Android bots, so start off
67 # with a very wide blacklist disabling all these tests on all Android bots.
68 if 'Android' in bot: # skia:3255
69 blacklist.extend('gpu skp _ gpu image _ gpu subset _'.split(' '))
70 blacklist.extend('msaa skp _ msaa image _ gpu subset _'.split(' '))
71
mtklein150d3502015-03-05 13:38:17 -080072 if 'Valgrind' in bot:
mtkleinde7665a2015-03-14 07:24:29 -070073 # PDF + .webp -> jumps depending on uninitialized memory. skia:3505
mtklein150d3502015-03-05 13:38:17 -080074 blacklist.extend('pdf _ .webp'.split(' '))
mtkleinde7665a2015-03-14 07:24:29 -070075 # These both take 18+ hours to run.
76 blacklist.extend('pdf gm fontmgr_iter'.split(' '))
77 blacklist.extend('pdf _ PANO_20121023_214540.jpg'.split(' '))
mtklein7e78f3d2015-03-10 08:03:26 -070078 if 'Valgrind_GPU' in bot:
borenet13e51f92015-03-09 06:59:16 -070079 args.append('--nocpu')
mtklein7e78f3d2015-03-10 08:03:26 -070080 elif 'Valgrind_CPU' in bot:
borenet13e51f92015-03-09 06:59:16 -070081 args.append('--nogpu')
mtklein150d3502015-03-05 13:38:17 -080082
mtklein11a2c502015-02-24 09:25:16 -080083 if blacklist:
84 args.append('--blacklist')
85 args.extend(blacklist)
86
87 match = []
88 if 'Alex' in bot: # skia:2793
89 # This machine looks to be running out of heap.
90 # Running with fewer threads may help.
91 args.extend(['--threads', '1'])
92 if 'Valgrind' in bot: # skia:3021
93 match.append('~Threaded')
mtklein905d01b2015-03-18 14:06:55 -070094 if 'TSAN' in bot: # skia:3562
95 match.append('~Math')
96
mtkleincc99dbc2015-03-11 08:43:43 -070097 if 'Xoom' in bot or 'GalaxyS3' in bot: # skia:1699
mtklein11a2c502015-02-24 09:25:16 -080098 match.append('~WritePixels')
99
100 # skia:3249: these images flakily don't decode on Android.
101 if 'Android' in bot:
102 match.append('~tabl_mozilla_0')
103 match.append('~desk_yahoonews_0')
104
mtklein4e2d3be2015-03-10 11:55:18 -0700105 if 'NexusPlayer' in bot:
106 match.append('~ResourceCache')
107
mtklein11a2c502015-02-24 09:25:16 -0800108 if match:
109 args.append('--match')
110 args.extend(match)
111
112 # Though their GPUs are interesting, these don't test anything on
113 # the CPU that other ARMv7+NEON bots don't test faster (N5).
114 if ('Nexus10' in bot or
115 'Nexus7' in bot or
116 'GalaxyS3' in bot or
117 'GalaxyS4' in bot):
118 args.append('--nocpu')
119 return args
120cov_end = lineno() # Don't care about code coverage past here.
121
122
123def self_test():
124 import coverage # This way the bots don't need coverage.py to be installed.
125 args = {}
126 cases = [
mtkleincc99dbc2015-03-11 08:43:43 -0700127 'Test-Android-GalaxyS3-Mali400-Arm7-Debug',
mtklein11a2c502015-02-24 09:25:16 -0800128 'Test-Android-Nexus7-Tegra3-Arm7-Release',
mtklein4e2d3be2015-03-10 11:55:18 -0700129 'Test-Android-NexusPlayer-PowerVR-x86-Release',
mtklein11a2c502015-02-24 09:25:16 -0800130 'Test-Android-Xoom-Tegra2-Arm7-Release',
131 'Test-ChromeOS-Alex-GMA3150-x86-Debug',
borenet13e51f92015-03-09 06:59:16 -0700132 'Test-Ubuntu12-ShuttleA-GTX550Ti-x86_64-Release-Valgrind_GPU',
mtklein905d01b2015-03-18 14:06:55 -0700133 'Test-Ubuntu13.10-GCE-NoGPU-x86_64-Release-TSAN',
mtklein4e2d3be2015-03-10 11:55:18 -0700134 'Test-Ubuntu14-GCE-NoGPU-x86_64-Release-Valgrind_CPU',
mtkleinee2a3ea2015-02-25 08:16:19 -0800135 'Test-Win7-ShuttleA-HD2000-x86-Debug-ANGLE',
mtklein11a2c502015-02-24 09:25:16 -0800136 ]
137
138 cov = coverage.coverage()
139 cov.start()
140 for case in cases:
mtkleinf73e5892015-02-24 11:45:11 -0800141 args[case] = get_args(case)
mtklein11a2c502015-02-24 09:25:16 -0800142 cov.stop()
143
144 this_file = os.path.basename(__file__)
145 _, _, not_run, _ = cov.analysis(this_file)
146 filtered = [line for line in not_run if line > cov_start and line < cov_end]
147 if filtered:
148 print 'Lines not covered by test cases: ', filtered
149 sys.exit(1)
150
151 golden = this_file.replace('.py', '.json')
152 with open(os.path.join(os.path.dirname(__file__), golden), 'w') as f:
153 json.dump(args, f, indent=2, sort_keys=True)
154
155
156if __name__ == '__main__':
157 if len(sys.argv) == 2 and sys.argv[1] == 'test':
158 self_test()
159 sys.exit(0)
160
161 if len(sys.argv) != 3:
162 print usage
163 sys.exit(1)
164
165 with open(sys.argv[1], 'w') as out:
mtkleinf73e5892015-02-24 11:45:11 -0800166 json.dump(get_args(sys.argv[2]), out)