You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			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 |