forked from OSchip/llvm-project
				
			
		
			
				
	
	
		
			182 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Python
		
	
	
	
			
		
		
	
	
			182 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Python
		
	
	
	
"""
 | 
						|
                     The LLVM Compiler Infrastructure
 | 
						|
 | 
						|
This file is distributed under the University of Illinois Open Source
 | 
						|
License. See LICENSE.TXT for details.
 | 
						|
 | 
						|
Provides the configuration class, which holds all information related to
 | 
						|
how this invocation of the test suite should be run.
 | 
						|
"""
 | 
						|
 | 
						|
from __future__ import absolute_import
 | 
						|
from __future__ import print_function
 | 
						|
 | 
						|
# System modules
 | 
						|
import os
 | 
						|
import platform
 | 
						|
import subprocess
 | 
						|
 | 
						|
 | 
						|
# Third-party modules
 | 
						|
import unittest2
 | 
						|
 | 
						|
# LLDB Modules
 | 
						|
import lldbsuite
 | 
						|
 | 
						|
 | 
						|
def __setCrashInfoHook_Mac(text):
 | 
						|
    from . import crashinfo
 | 
						|
    crashinfo.setCrashReporterDescription(text)
 | 
						|
 | 
						|
 | 
						|
def setupCrashInfoHook():
 | 
						|
    if platform.system() == "Darwin":
 | 
						|
        from . import lock
 | 
						|
        test_dir = os.environ['LLDB_TEST']
 | 
						|
        if not test_dir or not os.path.exists(test_dir):
 | 
						|
            return
 | 
						|
        dylib_lock = os.path.join(test_dir, "crashinfo.lock")
 | 
						|
        dylib_src = os.path.join(test_dir, "crashinfo.c")
 | 
						|
        dylib_dst = os.path.join(test_dir, "crashinfo.so")
 | 
						|
        try:
 | 
						|
            compile_lock = lock.Lock(dylib_lock)
 | 
						|
            compile_lock.acquire()
 | 
						|
            if not os.path.isfile(dylib_dst) or os.path.getmtime(
 | 
						|
                    dylib_dst) < os.path.getmtime(dylib_src):
 | 
						|
                # we need to compile
 | 
						|
                cmd = "SDKROOT= xcrun clang %s -o %s -framework Python -Xlinker -dylib" % (
 | 
						|
                    dylib_src, dylib_dst)
 | 
						|
                if subprocess.call(
 | 
						|
                        cmd, shell=True) != 0 or not os.path.isfile(dylib_dst):
 | 
						|
                    raise Exception('command failed: "{}"'.format(cmd))
 | 
						|
        finally:
 | 
						|
            compile_lock.release()
 | 
						|
            del compile_lock
 | 
						|
 | 
						|
        setCrashInfoHook = __setCrashInfoHook_Mac
 | 
						|
 | 
						|
    else:
 | 
						|
        pass
 | 
						|
 | 
						|
# The test suite.
 | 
						|
suite = unittest2.TestSuite()
 | 
						|
 | 
						|
# The list of categories we said we care about
 | 
						|
categoriesList = None
 | 
						|
# set to true if we are going to use categories for cherry-picking test cases
 | 
						|
useCategories = False
 | 
						|
# Categories we want to skip
 | 
						|
skipCategories = ["darwin-log"]
 | 
						|
# use this to track per-category failures
 | 
						|
failuresPerCategory = {}
 | 
						|
 | 
						|
# The path to LLDB.framework is optional.
 | 
						|
lldbFrameworkPath = None
 | 
						|
 | 
						|
# Test suite repeat count.  Can be overwritten with '-# count'.
 | 
						|
count = 1
 | 
						|
 | 
						|
# The 'arch' and 'compiler' can be specified via command line.
 | 
						|
arch = None        # Must be initialized after option parsing
 | 
						|
compiler = None    # Must be initialized after option parsing
 | 
						|
 | 
						|
# The arch might dictate some specific CFLAGS to be passed to the toolchain to build
 | 
						|
# the inferior programs.  The global variable cflags_extras provides a hook to do
 | 
						|
# just that.
 | 
						|
cflags_extras = ''
 | 
						|
 | 
						|
# The filters (testclass.testmethod) used to admit tests into our test suite.
 | 
						|
filters = []
 | 
						|
 | 
						|
# By default, we skip long running test case.  Use '-l' option to override.
 | 
						|
skip_long_running_test = True
 | 
						|
 | 
						|
# Parsable mode silences headers, and any other output this script might generate, and instead
 | 
						|
# prints machine-readable output similar to what clang tests produce.
 | 
						|
parsable = False
 | 
						|
 | 
						|
# The regular expression pattern to match against eligible filenames as
 | 
						|
# our test cases.
 | 
						|
regexp = None
 | 
						|
 | 
						|
# Sets of tests which are excluded at runtime
 | 
						|
skip_tests = None
 | 
						|
xfail_tests = None
 | 
						|
 | 
						|
# By default, recorded session info for errored/failed test are dumped into its
 | 
						|
# own file under a session directory named after the timestamp of the test suite
 | 
						|
# run.  Use '-s session-dir-name' to specify a specific dir name.
 | 
						|
sdir_name = None
 | 
						|
 | 
						|
# Valid options:
 | 
						|
# f - test file name (without extension)
 | 
						|
# n - test class name
 | 
						|
# m - test method name
 | 
						|
# a - architecture
 | 
						|
# c - compiler path
 | 
						|
# The default is to write all fields.
 | 
						|
session_file_format = 'fnmac'
 | 
						|
 | 
						|
# Set this flag if there is any session info dumped during the test run.
 | 
						|
sdir_has_content = False
 | 
						|
 | 
						|
# svn_info stores the output from 'svn info lldb.base.dir'.
 | 
						|
svn_info = ''
 | 
						|
 | 
						|
# Default verbosity is 0.
 | 
						|
verbose = 0
 | 
						|
 | 
						|
# By default, search from the script directory.
 | 
						|
# We can't use sys.path[0] to determine the script directory
 | 
						|
# because it doesn't work under a debugger
 | 
						|
testdirs = [os.path.dirname(os.path.realpath(__file__))]
 | 
						|
 | 
						|
# Separator string.
 | 
						|
separator = '-' * 70
 | 
						|
 | 
						|
failed = False
 | 
						|
 | 
						|
# LLDB Remote platform setting
 | 
						|
lldb_platform_name = None
 | 
						|
lldb_platform_url = None
 | 
						|
lldb_platform_working_dir = None
 | 
						|
 | 
						|
# Parallel execution settings
 | 
						|
is_inferior_test_runner = False
 | 
						|
multiprocess_test_subdir = None
 | 
						|
num_threads = None
 | 
						|
no_multiprocess_test_runner = False
 | 
						|
test_runner_name = None
 | 
						|
 | 
						|
# Test results handling globals
 | 
						|
results_filename = None
 | 
						|
results_port = None
 | 
						|
results_formatter_name = None
 | 
						|
results_formatter_object = None
 | 
						|
results_formatter_options = None
 | 
						|
test_result = None
 | 
						|
 | 
						|
# Test rerun configuration vars
 | 
						|
rerun_all_issues = False
 | 
						|
rerun_max_file_threhold = 0
 | 
						|
 | 
						|
# The names of all tests. Used to assert we don't have two tests with the
 | 
						|
# same base name.
 | 
						|
all_tests = set()
 | 
						|
 | 
						|
# safe default
 | 
						|
setCrashInfoHook = lambda x: None
 | 
						|
 | 
						|
 | 
						|
def shouldSkipBecauseOfCategories(test_categories):
 | 
						|
    if useCategories:
 | 
						|
        if len(test_categories) == 0 or len(
 | 
						|
                categoriesList & set(test_categories)) == 0:
 | 
						|
            return True
 | 
						|
 | 
						|
    for category in skipCategories:
 | 
						|
        if category in test_categories:
 | 
						|
            return True
 | 
						|
 | 
						|
    return False
 |