1"""
2                     The LLVM Compiler Infrastructure
3
4This file is distributed under the University of Illinois Open Source
5License. See LICENSE.TXT for details.
6
7Provides the configuration class, which holds all information related to
8how this invocation of the test suite should be run.
9"""
10
11from __future__ import absolute_import
12from __future__ import print_function
13
14# System modules
15import os
16import platform
17import subprocess
18
19
20# Third-party modules
21import unittest2
22
23# LLDB Modules
24import lldbsuite
25
26
27def __setCrashInfoHook_Mac(text):
28    from . import crashinfo
29    crashinfo.setCrashReporterDescription(text)
30
31
32def setupCrashInfoHook():
33    if platform.system() == "Darwin":
34        from . import lock
35        test_dir = os.environ['LLDB_TEST']
36        if not test_dir or not os.path.exists(test_dir):
37            return
38        dylib_lock = os.path.join(test_dir, "crashinfo.lock")
39        dylib_src = os.path.join(test_dir, "crashinfo.c")
40        dylib_dst = os.path.join(test_dir, "crashinfo.so")
41        try:
42            compile_lock = lock.Lock(dylib_lock)
43            compile_lock.acquire()
44            if not os.path.isfile(dylib_dst) or os.path.getmtime(
45                    dylib_dst) < os.path.getmtime(dylib_src):
46                # we need to compile
47                cmd = "SDKROOT= xcrun clang %s -o %s -framework Python -Xlinker -dylib -iframework /System/Library/Frameworks/ -Xlinker -F /System/Library/Frameworks/" % (
48                    dylib_src, dylib_dst)
49                if subprocess.call(
50                        cmd, shell=True) != 0 or not os.path.isfile(dylib_dst):
51                    raise Exception('command failed: "{}"'.format(cmd))
52        finally:
53            compile_lock.release()
54            del compile_lock
55
56        setCrashInfoHook = __setCrashInfoHook_Mac
57
58    else:
59        pass
60
61# The test suite.
62suite = unittest2.TestSuite()
63
64# The list of categories we said we care about
65categoriesList = None
66# set to true if we are going to use categories for cherry-picking test cases
67useCategories = False
68# Categories we want to skip
69skipCategories = []
70# use this to track per-category failures
71failuresPerCategory = {}
72
73# The path to LLDB.framework is optional.
74lldbFrameworkPath = None
75
76# Test suite repeat count.  Can be overwritten with '-# count'.
77count = 1
78
79# The 'archs' and 'compilers' can be specified via command line.  The corresponding
80# options can be specified more than once. For example, "-A x86_64 -A i386"
81# => archs=['x86_64', 'i386'] and "-C gcc -C clang" => compilers=['gcc', 'clang'].
82archs = None        # Must be initialized after option parsing
83compilers = None    # Must be initialized after option parsing
84
85# The arch might dictate some specific CFLAGS to be passed to the toolchain to build
86# the inferior programs.  The global variable cflags_extras provides a hook to do
87# just that.
88cflags_extras = ''
89
90# The filters (testclass.testmethod) used to admit tests into our test suite.
91filters = []
92
93# By default, we skip long running test case.  Use '-l' option to override.
94skip_long_running_test = True
95
96# Parsable mode silences headers, and any other output this script might generate, and instead
97# prints machine-readable output similar to what clang tests produce.
98parsable = False
99
100# The regular expression pattern to match against eligible filenames as
101# our test cases.
102regexp = None
103
104# Sets of tests which are excluded at runtime
105skip_tests = None
106xfail_tests = None
107
108# By default, recorded session info for errored/failed test are dumped into its
109# own file under a session directory named after the timestamp of the test suite
110# run.  Use '-s session-dir-name' to specify a specific dir name.
111sdir_name = None
112
113# Valid options:
114# f - test file name (without extension)
115# n - test class name
116# m - test method name
117# a - architecture
118# c - compiler path
119# The default is to write all fields.
120session_file_format = 'fnmac'
121
122# Set this flag if there is any session info dumped during the test run.
123sdir_has_content = False
124
125# svn_info stores the output from 'svn info lldb.base.dir'.
126svn_info = ''
127
128# Default verbosity is 0.
129verbose = 0
130
131# By default, search from the script directory.
132# We can't use sys.path[0] to determine the script directory
133# because it doesn't work under a debugger
134testdirs = [os.path.dirname(os.path.realpath(__file__))]
135
136# Separator string.
137separator = '-' * 70
138
139failed = False
140
141# LLDB Remote platform setting
142lldb_platform_name = None
143lldb_platform_url = None
144lldb_platform_working_dir = None
145
146# Parallel execution settings
147is_inferior_test_runner = False
148multiprocess_test_subdir = None
149num_threads = None
150no_multiprocess_test_runner = False
151test_runner_name = None
152
153# Test results handling globals
154results_filename = None
155results_port = None
156results_formatter_name = None
157results_formatter_object = None
158results_formatter_options = None
159test_result = None
160
161# Test rerun configuration vars
162rerun_all_issues = False
163rerun_max_file_threhold = 0
164
165# The names of all tests. Used to assert we don't have two tests with the
166# same base name.
167all_tests = set()
168
169# safe default
170setCrashInfoHook = lambda x: None
171
172
173def shouldSkipBecauseOfCategories(test_categories):
174    if useCategories:
175        if len(test_categories) == 0 or len(
176                categoriesList & set(test_categories)) == 0:
177            return True
178
179    for category in skipCategories:
180        if category in test_categories:
181            return True
182
183    return False
184