forked from OSchip/llvm-project
176 lines
4.3 KiB
Python
176 lines
4.3 KiB
Python
"""
|
|
Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
See https://llvm.org/LICENSE.txt for license information.
|
|
SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
|
|
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
|
|
|
|
|
|
# Third-party modules
|
|
import unittest2
|
|
|
|
# LLDB Modules
|
|
import lldbsuite
|
|
|
|
|
|
# The test suite.
|
|
suite = unittest2.TestSuite()
|
|
|
|
# The list of categories we said we care about
|
|
categories_list = None
|
|
# set to true if we are going to use categories for cherry-picking test cases
|
|
use_categories = False
|
|
# Categories we want to skip
|
|
skip_categories = ["darwin-log"]
|
|
# Categories we expect to fail
|
|
xfail_categories = []
|
|
# use this to track per-category failures
|
|
failures_per_category = {}
|
|
|
|
# The path to LLDB.framework is optional.
|
|
lldb_framework_path = None
|
|
|
|
# Test suite repeat count. Can be overwritten with '-# count'.
|
|
count = 1
|
|
|
|
# The 'arch' and 'compiler' can be specified via command line.
|
|
arch = None
|
|
compiler = None
|
|
dsymutil = None
|
|
sdkroot = None
|
|
|
|
# The overriden dwarf verison.
|
|
dwarf_version = 0
|
|
|
|
# Any overridden settings.
|
|
# Always disable default dynamic types for testing purposes.
|
|
settings = [('target.prefer-dynamic-value', 'no-dynamic-values')]
|
|
|
|
# Path to the FileCheck testing tool. Not optional.
|
|
filecheck = None
|
|
|
|
# Path to the yaml2obj tool. Not optional.
|
|
yaml2obj = None
|
|
|
|
# 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 = []
|
|
|
|
# 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
|
|
|
|
# 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 = [lldbsuite.lldb_test_root]
|
|
|
|
# The root of the test case tree (where the actual tests reside, not the test
|
|
# infrastructure).
|
|
test_src_root = lldbsuite.lldb_test_root
|
|
|
|
# Separator string.
|
|
separator = '-' * 70
|
|
|
|
failed = False
|
|
|
|
# LLDB Remote platform setting
|
|
lldb_platform_name = None
|
|
lldb_platform_url = None
|
|
lldb_platform_working_dir = None
|
|
|
|
# Apple SDK
|
|
apple_sdk = None
|
|
|
|
# The base directory in which the tests are being built.
|
|
test_build_dir = None
|
|
|
|
# The clang module cache directory used by lldb.
|
|
lldb_module_cache_dir = None
|
|
# The clang module cache directory used by clang.
|
|
clang_module_cache_dir = None
|
|
|
|
# Test results handling globals
|
|
test_result = None
|
|
|
|
# Reproducers
|
|
capture_path = None
|
|
replay_path = None
|
|
|
|
# The names of all tests. Used to assert we don't have two tests with the
|
|
# same base name.
|
|
all_tests = set()
|
|
|
|
# LLDB library directory.
|
|
lldb_libs_dir = None
|
|
|
|
# A plugin whose tests will be enabled, like intel-pt.
|
|
enabled_plugins = []
|
|
|
|
|
|
def shouldSkipBecauseOfCategories(test_categories):
|
|
if use_categories:
|
|
if len(test_categories) == 0 or len(
|
|
categories_list & set(test_categories)) == 0:
|
|
return True
|
|
|
|
for category in skip_categories:
|
|
if category in test_categories:
|
|
return True
|
|
|
|
return False
|
|
|
|
|
|
def get_filecheck_path():
|
|
"""
|
|
Get the path to the FileCheck testing tool.
|
|
"""
|
|
if filecheck and os.path.lexists(filecheck):
|
|
return filecheck
|
|
|
|
def get_yaml2obj_path():
|
|
"""
|
|
Get the path to the yaml2obj tool.
|
|
"""
|
|
if yaml2obj and os.path.lexists(yaml2obj):
|
|
return yaml2obj
|
|
|
|
def is_reproducer_replay():
|
|
"""
|
|
Returns true when dotest is being replayed from a reproducer. Never use
|
|
this method to guard SB API calls as it will cause a divergence between
|
|
capture and replay.
|
|
"""
|
|
return replay_path is not None
|
|
|
|
def is_reproducer():
|
|
"""
|
|
Returns true when dotest is capturing a reproducer or is being replayed
|
|
from a reproducer. Use this method to guard SB API calls.
|
|
"""
|
|
return capture_path or replay_path
|