blob: 5d1bf751903cd64872668d1f8c2dc49db362e7a2 [file] [log] [blame]
Zachary Turnerff890da2015-10-19 23:45:41 +00001from __future__ import print_function
2
Zachary Turner3ad38742015-10-23 17:53:30 +00003import argparse
Vince Harronf8b9a1d2015-05-18 19:40:54 +00004import sys
Todd Fialae83f1402015-09-18 22:45:31 +00005import multiprocessing
Vince Harronf8b9a1d2015-05-18 19:40:54 +00006import os
7import textwrap
8
Vince Harronf8b9a1d2015-05-18 19:40:54 +00009class ArgParseNamespace(object):
10 pass
11
12def parse_args(parser, argv):
13 """ Returns an argument object. LLDB_TEST_ARGUMENTS environment variable can
Zachary Turner3ad38742015-10-23 17:53:30 +000014 be used to pass additional arguments.
Vince Harronf8b9a1d2015-05-18 19:40:54 +000015 """
Zachary Turner3ad38742015-10-23 17:53:30 +000016 args = ArgParseNamespace()
Vince Harronf8b9a1d2015-05-18 19:40:54 +000017
Zachary Turner3ad38742015-10-23 17:53:30 +000018 if ('LLDB_TEST_ARGUMENTS' in os.environ):
19 print("Arguments passed through environment: '%s'" % os.environ['LLDB_TEST_ARGUMENTS'])
20 args = parser.parse_args([sys.argv[0]].__add__(os.environ['LLDB_TEST_ARGUMENTS'].split()),namespace=args)
Vince Harronf8b9a1d2015-05-18 19:40:54 +000021
Zachary Turner3ad38742015-10-23 17:53:30 +000022 return parser.parse_args(args=argv, namespace=args)
Vince Harronf8b9a1d2015-05-18 19:40:54 +000023
Todd Fialae83f1402015-09-18 22:45:31 +000024
25def default_thread_count():
26 # Check if specified in the environment
27 num_threads_str = os.environ.get("LLDB_TEST_THREADS")
28 if num_threads_str:
29 return int(num_threads_str)
30 else:
31 return multiprocessing.cpu_count()
32
33
Vince Harron8994fed2015-05-22 19:49:23 +000034def create_parser():
Vince Harronf8b9a1d2015-05-18 19:40:54 +000035 parser = argparse.ArgumentParser(description='description', prefix_chars='+-', add_help=False)
36 group = None
37
38 # Helper function for boolean options (group will point to the current group when executing X)
39 X = lambda optstr, helpstr, **kwargs: group.add_argument(optstr, help=helpstr, action='store_true', **kwargs)
40
41 group = parser.add_argument_group('Help')
42 group.add_argument('-h', '--help', dest='h', action='store_true', help="Print this help message and exit. Add '-v' for more detailed help.")
43
44 # C and Python toolchain options
45 group = parser.add_argument_group('Toolchain options')
46 group.add_argument('-A', '--arch', metavar='arch', action='append', dest='archs', help=textwrap.dedent('''Specify the architecture(s) to test. This option can be specified more than once'''))
47 group.add_argument('-C', '--compiler', metavar='compiler', dest='compilers', action='append', help=textwrap.dedent('''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.'''))
48 if sys.platform == 'darwin':
49 group.add_argument('--apple-sdk', metavar='apple_sdk', dest='apple_sdk', help=textwrap.dedent('''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.'''))
50 # FIXME? This won't work for different extra flags according to each arch.
51 group.add_argument('-E', metavar='extra-flags', help=textwrap.dedent('''Specify the extra flags to be passed to the toolchain when building the inferior programs to be debugged
52 suggestions: do not lump the "-A arch1 -A arch2" together such that the -E option applies to only one of the architectures'''))
53 X('-D', 'Dump the Python sys.path variable')
54
55 # Test filtering options
56 group = parser.add_argument_group('Test filtering options')
Tamas Berghammer4c0c7a72015-10-07 10:02:17 +000057 group.add_argument('-N', choices=['dwarf', 'dwo', 'dsym'], help="Don't do test cases marked with the @dsym_test/@dwarf_test/@dwo_test decorator by passing dsym/dwarf/dwo as the option arg")
Vince Harronf8b9a1d2015-05-18 19:40:54 +000058 X('-a', "Don't do lldb Python API tests")
59 X('+a', "Just do lldb Python API tests. Do not specify along with '-a'", dest='plus_a')
60 X('+b', 'Just do benchmark tests', dest='plus_b')
61 group.add_argument('-b', metavar='blacklist', help='Read a blacklist file specified after this option')
62 group.add_argument('-f', metavar='filterspec', action='append', 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?
63 X('-g', 'If specified, the filterspec by -f is not exclusive, i.e., if a test module does not match the filterspec (testclass.testmethod), the whole module is still admitted to the test suite')
64 X('-l', "Don't skip long running tests")
65 X('-m', "Don't do lldb-mi tests")
66 X('+m', "Just do lldb-mi tests. Do not specify along with '-m'", dest='plus_m')
67 group.add_argument('-p', metavar='pattern', help='Specify a regexp filename pattern for inclusion in the test suite')
68 group.add_argument('-X', metavar='directory', help="Exclude a directory from consideration for test discovery. -X types => if 'types' appear in the pathname components of a potential testfile, it will be ignored")
69 group.add_argument('-G', '--category', metavar='category', action='append', dest='categoriesList', help=textwrap.dedent('''Specify categories of test cases of interest. Can be specified more than once.'''))
70 group.add_argument('--skip-category', metavar='category', action='append', dest='skipCategories', help=textwrap.dedent('''Specify categories of test cases to skip. Takes precedence over -G. Can be specified more than once.'''))
71
72 # Configuration options
73 group = parser.add_argument_group('Configuration options')
74 group.add_argument('-c', metavar='config-file', help='Read a config file specified after this option') # FIXME: additional doc.
75 group.add_argument('--framework', metavar='framework-path', help='The path to LLDB.framework')
76 group.add_argument('--executable', metavar='executable-path', help='The path to the lldb executable')
77 group.add_argument('--libcxx', metavar='directory', help='The path to custom libc++ library')
78 group.add_argument('-e', metavar='benchmark-exe', help='Specify the full path of an executable used for benchmark purposes (see also: -x)')
79 group.add_argument('-k', metavar='command', action='append', help="Specify a runhook, which is an lldb command to be executed by the debugger; The option can occur multiple times. The commands are executed one after the other to bring the debugger to a desired state, so that, for example, further benchmarking can be done")
80 group.add_argument('-R', metavar='dir', help='Specify a directory to relocate the tests and their intermediate files to. BE WARNED THAT the directory, if exists, will be deleted before running this test driver. No cleanup of intermediate test files is performed in this case')
81 group.add_argument('-r', metavar='dir', help="Similar to '-R', except that the directory must not exist before running this test driver")
82 group.add_argument('-s', metavar='name', 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')
83 group.add_argument('-x', metavar='breakpoint-spec', help='Specify the breakpoint specification for the benchmark executable')
84 group.add_argument('-y', type=int, metavar='count', 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.")
85 group.add_argument('-#', type=int, metavar='sharp', dest='sharp', help='Repeat the test suite for a specified number of times')
86 group.add_argument('--channel', metavar='channel', dest='channels', action='append', help=textwrap.dedent("Specify the log channels (and optional categories) e.g. 'lldb all' or 'gdb-remote packets' if no categories are specified, 'default' is used"))
87 group.add_argument('--log-success', dest='log_success', action='store_true', help="Leave logs/traces even for successful test runs (useful for creating reference log files during debugging.)")
88
89 # Configuration options
90 group = parser.add_argument_group('Remote platform options')
91 group.add_argument('--platform-name', dest='lldb_platform_name', metavar='platform-name', help='The name of a remote platform to use')
92 group.add_argument('--platform-url', dest='lldb_platform_url', metavar='platform-url', help='A LLDB platform URL to use when connecting to a remote platform to run the test suite')
93 group.add_argument('--platform-working-dir', dest='lldb_platform_working_dir', metavar='platform-working-dir', help='The directory to use on the remote platform.')
94
95 # Test-suite behaviour
96 group = parser.add_argument_group('Runtime behaviour options')
97 X('-d', 'Suspend the process after launch to wait indefinitely for a debugger to attach')
98 X('-F', 'Fail fast. Stop the test suite on the first error/failure')
99 X('-i', "Ignore (don't bailout) if 'lldb.py' module cannot be located in the build tree relative to this script; use PYTHONPATH to locate the module")
100 X('-n', "Don't print the headers like build dir, lldb version, and svn info at all")
101 X('-P', "Use the graphic progress bar.")
102 X('-q', "Don't print extra output from this script.")
103 X('-S', "Skip the build and cleanup while running the test. Use this option with care as you would need to build the inferior(s) by hand and build the executable(s) with the correct name(s). This can be used with '-# n' to stress test certain test cases for n number of times")
104 X('-t', 'Turn on tracing of lldb command and other detailed test executions')
105 group.add_argument('-u', dest='unset_env_varnames', metavar='variable', action='append', help='Specify an environment variable to unset before running the test cases. e.g., -u DYLD_INSERT_LIBRARIES -u MallocScribble')
106 group.add_argument('--env', dest='set_env_vars', metavar='variable', action='append', 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')
107 X('-v', 'Do verbose mode of unittest framework (print out each test case invocation)')
108 X('-w', 'Insert some wait time (currently 0.5 sec) between consecutive test cases')
109 X('-T', 'Obtain and dump svn information for this checkout of LLDB (off by default)')
110 group.add_argument('--enable-crash-dialog', dest='disable_crash_dialog', action='store_false', help='(Windows only) When LLDB crashes, display the Windows crash dialog.')
111 group.add_argument('--show-inferior-console', dest='hide_inferior_console', action='store_false', help='(Windows only) When launching an inferior, dont hide its console window.')
112 group.set_defaults(disable_crash_dialog=True)
113 group.set_defaults(hide_inferior_console=True)
114
Todd Fialafed95662015-09-03 18:58:44 +0000115 group = parser.add_argument_group('Parallel execution options')
116 group.add_argument(
117 '--inferior',
118 action='store_true',
119 help=('specify this invocation is a multiprocess inferior, '
120 'used internally'))
121 group.add_argument(
122 '--no-multiprocess',
123 action='store_true',
124 help='skip running the multiprocess test runner')
125 group.add_argument(
126 '--output-on-success',
127 action='store_true',
128 help=('print full output of the dotest.py inferior, '
129 'even when all tests succeed'))
130 group.add_argument(
131 '--threads',
132 type=int,
133 dest='num_threads',
Todd Fialae83f1402015-09-18 22:45:31 +0000134 default=default_thread_count(),
Todd Fialafed95662015-09-03 18:58:44 +0000135 help=('The number of threads/processes to use when running tests '
136 'separately, defaults to the number of CPU cores available'))
Todd Fiala8cbeed32015-09-08 22:22:33 +0000137 group.add_argument(
Todd Fialafed95662015-09-03 18:58:44 +0000138 '--test-subdir',
139 action='store',
140 help='Specify a test subdirectory to use relative to the test root dir'
141 )
Todd Fiala8cbeed32015-09-08 22:22:33 +0000142 group.add_argument(
143 '--test-runner-name',
144 action='store',
145 help=('Specify a test runner strategy. Valid values: multiprocessing,'
146 ' multiprocessing-pool, serial, threading, threading-pool')
147 )
Todd Fialafed95662015-09-03 18:58:44 +0000148
Todd Fiala68615ce2015-09-15 21:38:04 +0000149 # Test results support.
150 group = parser.add_argument_group('Test results options')
151 group.add_argument(
152 '--results-file',
153 action='store',
154 help=('Specifies the file where test results will be written '
155 'according to the results-formatter class used'))
156 group.add_argument(
157 '--results-port',
158 action='store',
159 type=int,
160 help=('Specifies the localhost port to which the results '
161 'formatted output should be sent'))
162 group.add_argument(
163 '--results-formatter',
164 action='store',
165 help=('Specifies the full package/module/class name used to translate '
166 'test events into some kind of meaningful report, written to '
167 'the designated output results file-like object'))
168 group.add_argument(
Todd Fialaea736242015-09-23 15:21:28 +0000169 '--results-formatter-option',
170 '-O',
171 action='append',
172 dest='results_formatter_options',
173 help=('Specify an option to pass to the formatter. '
174 'Use --results-formatter-option="--option1=val1" '
175 'syntax. Note the "=" is critical, don\'t include whitespace.'))
Todd Fiala33896a92015-09-18 21:01:13 +0000176 group.add_argument(
177 '--event-add-entries',
178 action='store',
179 help=('Specify comma-separated KEY=VAL entries to add key and value '
Todd Fiala40b180e2015-09-18 23:46:30 +0000180 'pairs to all test events generated by this test run. VAL may '
181 'be specified as VAL:TYPE, where TYPE may be int to convert '
182 'the value to an int'))
Vince Harronf8b9a1d2015-05-18 19:40:54 +0000183 # Remove the reference to our helper function
184 del X
185
186 group = parser.add_argument_group('Test directories')
187 group.add_argument('args', metavar='test-dir', nargs='*', 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.')
188
Vince Harron8994fed2015-05-22 19:49:23 +0000189 return parser