blob: 0b8470bcaa817510545cd12f5fddd511fe0711f9 [file] [log] [blame]
Zachary Turnerff890da2015-10-19 23:45:41 +00001from __future__ import print_function
Zachary Turnerc1b7cd72015-11-05 19:22:28 +00002from __future__ import absolute_import
Zachary Turnerff890da2015-10-19 23:45:41 +00003
Zachary Turnerc1b7cd72015-11-05 19:22:28 +00004# System modules
Zachary Turner3ad38742015-10-23 17:53:30 +00005import argparse
Vince Harronf8b9a1d2015-05-18 19:40:54 +00006import sys
Todd Fialae83f1402015-09-18 22:45:31 +00007import multiprocessing
Vince Harronf8b9a1d2015-05-18 19:40:54 +00008import os
9import textwrap
10
Zachary Turnerc1b7cd72015-11-05 19:22:28 +000011# Third-party modules
12
13# LLDB modules
Zachary Turner8d4d1512016-05-17 18:02:34 +000014from . import configuration
Zachary Turnerc1b7cd72015-11-05 19:22:28 +000015
Kate Stoneb9c1b512016-09-06 20:57:50 +000016
Vince Harronf8b9a1d2015-05-18 19:40:54 +000017class ArgParseNamespace(object):
18 pass
19
Kate Stoneb9c1b512016-09-06 20:57:50 +000020
Vince Harronf8b9a1d2015-05-18 19:40:54 +000021def parse_args(parser, argv):
22 """ Returns an argument object. LLDB_TEST_ARGUMENTS environment variable can
Zachary Turner3ad38742015-10-23 17:53:30 +000023 be used to pass additional arguments.
Vince Harronf8b9a1d2015-05-18 19:40:54 +000024 """
Zachary Turner3ad38742015-10-23 17:53:30 +000025 args = ArgParseNamespace()
Vince Harronf8b9a1d2015-05-18 19:40:54 +000026
Zachary Turner3ad38742015-10-23 17:53:30 +000027 if ('LLDB_TEST_ARGUMENTS' in os.environ):
Kate Stoneb9c1b512016-09-06 20:57:50 +000028 print(
29 "Arguments passed through environment: '%s'" %
30 os.environ['LLDB_TEST_ARGUMENTS'])
31 args = parser.parse_args([sys.argv[0]].__add__(
32 os.environ['LLDB_TEST_ARGUMENTS'].split()), namespace=args)
Vince Harronf8b9a1d2015-05-18 19:40:54 +000033
Zachary Turner3ad38742015-10-23 17:53:30 +000034 return parser.parse_args(args=argv, namespace=args)
Vince Harronf8b9a1d2015-05-18 19:40:54 +000035
Todd Fialae83f1402015-09-18 22:45:31 +000036
37def default_thread_count():
38 # Check if specified in the environment
39 num_threads_str = os.environ.get("LLDB_TEST_THREADS")
40 if num_threads_str:
41 return int(num_threads_str)
42 else:
43 return multiprocessing.cpu_count()
44
45
Vince Harron8994fed2015-05-22 19:49:23 +000046def create_parser():
Kate Stoneb9c1b512016-09-06 20:57:50 +000047 parser = argparse.ArgumentParser(
48 description='description',
49 prefix_chars='+-',
50 add_help=False)
Vince Harronf8b9a1d2015-05-18 19:40:54 +000051 group = None
52
Kate Stoneb9c1b512016-09-06 20:57:50 +000053 # Helper function for boolean options (group will point to the current
54 # group when executing X)
55 X = lambda optstr, helpstr, **kwargs: group.add_argument(
56 optstr, help=helpstr, action='store_true', **kwargs)
Vince Harronf8b9a1d2015-05-18 19:40:54 +000057
58 group = parser.add_argument_group('Help')
Kate Stoneb9c1b512016-09-06 20:57:50 +000059 group.add_argument(
60 '-h',
61 '--help',
62 dest='h',
63 action='store_true',
64 help="Print this help message and exit. Add '-v' for more detailed help.")
Vince Harronf8b9a1d2015-05-18 19:40:54 +000065
66 # C and Python toolchain options
67 group = parser.add_argument_group('Toolchain options')
Kate Stoneb9c1b512016-09-06 20:57:50 +000068 group.add_argument(
69 '-A',
70 '--arch',
71 metavar='arch',
72 action='append',
73 dest='archs',
74 help=textwrap.dedent('''Specify the architecture(s) to test. This option can be specified more than once'''))
75 group.add_argument('-C', '--compiler', metavar='compiler', dest='compilers', action='append', help=textwrap.dedent(
76 '''Specify the compiler(s) used to build the inferior executables. The compiler path can be an executable basename or a full path to a compiler executable. This option can be specified multiple times.'''))
Vince Harronf8b9a1d2015-05-18 19:40:54 +000077 if sys.platform == 'darwin':
Kate Stoneb9c1b512016-09-06 20:57:50 +000078 group.add_argument('--apple-sdk', metavar='apple_sdk', dest='apple_sdk', help=textwrap.dedent(
79 '''Specify the name of the Apple SDK (macosx, macosx.internal, iphoneos, iphoneos.internal, or path to SDK) and use the appropriate tools from that SDK's toolchain.'''))
Vince Harronf8b9a1d2015-05-18 19:40:54 +000080 # FIXME? This won't work for different extra flags according to each arch.
Kate Stoneb9c1b512016-09-06 20:57:50 +000081 group.add_argument(
82 '-E',
83 metavar='extra-flags',
84 help=textwrap.dedent('''Specify the extra flags to be passed to the toolchain when building the inferior programs to be debugged
Vince Harronf8b9a1d2015-05-18 19:40:54 +000085 suggestions: do not lump the "-A arch1 -A arch2" together such that the -E option applies to only one of the architectures'''))
Vince Harronf8b9a1d2015-05-18 19:40:54 +000086
87 # Test filtering options
88 group = parser.add_argument_group('Test filtering options')
Kate Stoneb9c1b512016-09-06 20:57:50 +000089 group.add_argument(
90 '-f',
91 metavar='filterspec',
92 action='append',
93 help='Specify a filter, which consists of the test class name, a dot, followed by the test method, to only admit such test into the test suite') # FIXME: Example?
Vince Harronf8b9a1d2015-05-18 19:40:54 +000094 X('-l', "Don't skip long running tests")
Kate Stoneb9c1b512016-09-06 20:57:50 +000095 group.add_argument(
96 '-p',
97 metavar='pattern',
98 help='Specify a regexp filename pattern for inclusion in the test suite')
Francis Riccif833f172016-10-04 18:48:00 +000099 group.add_argument('--excluded', metavar='exclusion-file', action='append', help=textwrap.dedent(
Francis Ricci69517072016-09-23 21:32:47 +0000100 '''Specify a file for tests to exclude. File should contain lists of regular expressions for test files or methods,
101 with each list under a matching header (xfail files, xfail methods, skip files, skip methods)'''))
Kate Stoneb9c1b512016-09-06 20:57:50 +0000102 group.add_argument(
103 '-G',
104 '--category',
105 metavar='category',
106 action='append',
107 dest='categoriesList',
108 help=textwrap.dedent('''Specify categories of test cases of interest. Can be specified more than once.'''))
109 group.add_argument(
110 '--skip-category',
111 metavar='category',
112 action='append',
113 dest='skipCategories',
114 help=textwrap.dedent('''Specify categories of test cases to skip. Takes precedence over -G. Can be specified more than once.'''))
Vince Harronf8b9a1d2015-05-18 19:40:54 +0000115
116 # Configuration options
117 group = parser.add_argument_group('Configuration options')
Kate Stoneb9c1b512016-09-06 20:57:50 +0000118 group.add_argument(
119 '--framework',
120 metavar='framework-path',
121 help='The path to LLDB.framework')
122 group.add_argument(
123 '--executable',
124 metavar='executable-path',
125 help='The path to the lldb executable')
126 group.add_argument(
127 '-s',
128 metavar='name',
129 help='Specify the name of the dir created to store the session files of tests with errored or failed status. If not specified, the test driver uses the timestamp as the session dir name')
130 group.add_argument(
131 '-S',
132 '--session-file-format',
133 default=configuration.session_file_format,
134 metavar='format',
135 help='Specify session file name format. See configuration.py for a description.')
136 group.add_argument(
137 '-y',
138 type=int,
139 metavar='count',
140 help="Specify the iteration count used to collect our benchmarks. An example is the number of times to do 'thread step-over' to measure stepping speed.")
141 group.add_argument(
142 '-#',
143 type=int,
144 metavar='sharp',
145 dest='sharp',
146 help='Repeat the test suite for a specified number of times')
147 group.add_argument('--channel', metavar='channel', dest='channels', action='append', help=textwrap.dedent(
148 "Specify the log channels (and optional categories) e.g. 'lldb all' or 'gdb-remote packets' if no categories are specified, 'default' is used"))
149 group.add_argument(
150 '--log-success',
151 dest='log_success',
152 action='store_true',
153 help="Leave logs/traces even for successful test runs (useful for creating reference log files during debugging.)")
Vince Harronf8b9a1d2015-05-18 19:40:54 +0000154
155 # Configuration options
156 group = parser.add_argument_group('Remote platform options')
Kate Stoneb9c1b512016-09-06 20:57:50 +0000157 group.add_argument(
158 '--platform-name',
159 dest='lldb_platform_name',
160 metavar='platform-name',
161 help='The name of a remote platform to use')
162 group.add_argument(
163 '--platform-url',
164 dest='lldb_platform_url',
165 metavar='platform-url',
166 help='A LLDB platform URL to use when connecting to a remote platform to run the test suite')
167 group.add_argument(
168 '--platform-working-dir',
169 dest='lldb_platform_working_dir',
170 metavar='platform-working-dir',
171 help='The directory to use on the remote platform.')
Vince Harronf8b9a1d2015-05-18 19:40:54 +0000172
173 # Test-suite behaviour
174 group = parser.add_argument_group('Runtime behaviour options')
175 X('-d', 'Suspend the process after launch to wait indefinitely for a debugger to attach')
Vince Harronf8b9a1d2015-05-18 19:40:54 +0000176 X('-q', "Don't print extra output from this script.")
Vince Harronf8b9a1d2015-05-18 19:40:54 +0000177 X('-t', 'Turn on tracing of lldb command and other detailed test executions')
Kate Stoneb9c1b512016-09-06 20:57:50 +0000178 group.add_argument(
179 '-u',
180 dest='unset_env_varnames',
181 metavar='variable',
182 action='append',
183 help='Specify an environment variable to unset before running the test cases. e.g., -u DYLD_INSERT_LIBRARIES -u MallocScribble')
184 group.add_argument(
185 '--env',
186 dest='set_env_vars',
187 metavar='variable',
188 action='append',
189 help='Specify an environment variable to set to the given value before running the test cases e.g.: --env CXXFLAGS=-O3 --env DYLD_INSERT_LIBRARIES')
Vince Harronf8b9a1d2015-05-18 19:40:54 +0000190 X('-v', 'Do verbose mode of unittest framework (print out each test case invocation)')
Kate Stoneb9c1b512016-09-06 20:57:50 +0000191 group.add_argument(
192 '--enable-crash-dialog',
193 dest='disable_crash_dialog',
194 action='store_false',
195 help='(Windows only) When LLDB crashes, display the Windows crash dialog.')
Vince Harronf8b9a1d2015-05-18 19:40:54 +0000196 group.set_defaults(disable_crash_dialog=True)
Vince Harronf8b9a1d2015-05-18 19:40:54 +0000197
Todd Fialafed95662015-09-03 18:58:44 +0000198 group = parser.add_argument_group('Parallel execution options')
199 group.add_argument(
200 '--inferior',
201 action='store_true',
202 help=('specify this invocation is a multiprocess inferior, '
203 'used internally'))
204 group.add_argument(
205 '--no-multiprocess',
206 action='store_true',
207 help='skip running the multiprocess test runner')
208 group.add_argument(
Todd Fialafed95662015-09-03 18:58:44 +0000209 '--threads',
210 type=int,
211 dest='num_threads',
Todd Fialae83f1402015-09-18 22:45:31 +0000212 default=default_thread_count(),
Todd Fialafed95662015-09-03 18:58:44 +0000213 help=('The number of threads/processes to use when running tests '
214 'separately, defaults to the number of CPU cores available'))
Todd Fiala8cbeed32015-09-08 22:22:33 +0000215 group.add_argument(
Todd Fialafed95662015-09-03 18:58:44 +0000216 '--test-subdir',
217 action='store',
218 help='Specify a test subdirectory to use relative to the test root dir'
219 )
Todd Fiala8cbeed32015-09-08 22:22:33 +0000220 group.add_argument(
221 '--test-runner-name',
222 action='store',
223 help=('Specify a test runner strategy. Valid values: multiprocessing,'
224 ' multiprocessing-pool, serial, threading, threading-pool')
225 )
Todd Fialafed95662015-09-03 18:58:44 +0000226
Todd Fiala68615ce2015-09-15 21:38:04 +0000227 # Test results support.
228 group = parser.add_argument_group('Test results options')
229 group.add_argument(
Todd Fialacee6a6a2015-11-09 18:51:04 +0000230 '--curses',
231 action='store_true',
232 help='Shortcut for specifying test results using the curses formatter')
233 group.add_argument(
Todd Fiala68615ce2015-09-15 21:38:04 +0000234 '--results-file',
235 action='store',
236 help=('Specifies the file where test results will be written '
237 'according to the results-formatter class used'))
238 group.add_argument(
239 '--results-port',
240 action='store',
241 type=int,
242 help=('Specifies the localhost port to which the results '
243 'formatted output should be sent'))
244 group.add_argument(
245 '--results-formatter',
246 action='store',
247 help=('Specifies the full package/module/class name used to translate '
248 'test events into some kind of meaningful report, written to '
249 'the designated output results file-like object'))
250 group.add_argument(
Todd Fialaea736242015-09-23 15:21:28 +0000251 '--results-formatter-option',
252 '-O',
253 action='append',
254 dest='results_formatter_options',
255 help=('Specify an option to pass to the formatter. '
256 'Use --results-formatter-option="--option1=val1" '
257 'syntax. Note the "=" is critical, don\'t include whitespace.'))
Todd Fiala33896a92015-09-18 21:01:13 +0000258 group.add_argument(
259 '--event-add-entries',
260 action='store',
261 help=('Specify comma-separated KEY=VAL entries to add key and value '
Todd Fiala40b180e2015-09-18 23:46:30 +0000262 'pairs to all test events generated by this test run. VAL may '
263 'be specified as VAL:TYPE, where TYPE may be int to convert '
264 'the value to an int'))
Todd Fiala93153922015-12-12 19:26:56 +0000265
Todd Fiala685a7572015-12-14 21:28:46 +0000266 # Re-run related arguments
Todd Fiala93153922015-12-12 19:26:56 +0000267 group = parser.add_argument_group('Test Re-run Options')
268 group.add_argument(
269 '--rerun-all-issues',
270 action='store_true',
271 help=('Re-run all issues that occurred during the test run '
272 'irrespective of the test method\'s marking as flakey. '
273 'Default behavior is to apply re-runs only to flakey '
274 'tests that generate issues.'))
Todd Fiala685a7572015-12-14 21:28:46 +0000275 group.add_argument(
276 '--rerun-max-file-threshold',
277 action='store',
278 type=int,
279 default=50,
280 help=('Maximum number of files requiring a rerun beyond '
281 'which the rerun will not occur. This is meant to '
282 'stop a catastrophically failing test suite from forcing '
283 'all tests to be rerun in the single-worker phase.'))
284
Vince Harronf8b9a1d2015-05-18 19:40:54 +0000285 # Remove the reference to our helper function
286 del X
287
288 group = parser.add_argument_group('Test directories')
Kate Stoneb9c1b512016-09-06 20:57:50 +0000289 group.add_argument(
290 'args',
291 metavar='test-dir',
292 nargs='*',
293 help='Specify a list of directory names to search for test modules named after Test*.py (test discovery). If empty, search from the current working directory instead.')
Vince Harronf8b9a1d2015-05-18 19:40:54 +0000294
Vince Harron8994fed2015-05-22 19:49:23 +0000295 return parser