diff options
author | Siva Chandra <sivachandra@google.com> | 2015-11-20 20:30:36 +0000 |
---|---|---|
committer | Siva Chandra <sivachandra@google.com> | 2015-11-20 20:30:36 +0000 |
commit | 7dcad3178b883ea5e8d19ce565d443aa3b1df0b9 (patch) | |
tree | 391a5ea353a1696bf2a814d4f51e298e79437fec /lldb/packages/Python | |
parent | bc6d21d990dd2897da023a6887c17b7a723e7066 (diff) | |
download | bcm5719-llvm-7dcad3178b883ea5e8d19ce565d443aa3b1df0b9.tar.gz bcm5719-llvm-7dcad3178b883ea5e8d19ce565d443aa3b1df0b9.zip |
Revert "Make skipIf support the not_in function (second attempt)."
Summary: This reverts commit 70dca28976ee8137acce2cc203dd394f4d761276.
Reviewers: amccarth, zturner
Subscribers: lldb-commits
Differential Revision: http://reviews.llvm.org/D14881
llvm-svn: 253704
Diffstat (limited to 'lldb/packages/Python')
-rw-r--r-- | lldb/packages/Python/lldbsuite/test/lldbtest.py | 26 |
1 files changed, 11 insertions, 15 deletions
diff --git a/lldb/packages/Python/lldbsuite/test/lldbtest.py b/lldb/packages/Python/lldbsuite/test/lldbtest.py index 8a35533e39c..2301616bbfc 100644 --- a/lldb/packages/Python/lldbsuite/test/lldbtest.py +++ b/lldb/packages/Python/lldbsuite/test/lldbtest.py @@ -648,15 +648,11 @@ def expectedFailure(expected_fn, bugnumber=None): def not_in (iterable): return lambda x : x not in iterable -def check_decorator_attribute(attr, value):
- if attr is None:
- return True
- if six.callable(attr):
- return attr(value)
- elif isinstance(attr, (list, tuple)):
- return value in attr
- else:
- return value == attr +def check_list_or_lambda (list_or_lambda, value): + if six.callable(list_or_lambda): + return list_or_lambda(value) + else: + return list_or_lambda is None or value is None or value in list_or_lambda # provide a function to xfail on defined oslist, compiler version, and archs # if none is specified for any argument, that argument won't be checked and thus means for all @@ -666,11 +662,11 @@ def check_decorator_attribute(attr, value): # @expectedFailureAll(bugnumber, ["linux"], "gcc", ['>=', '4.9'], ['i386']), xfail for gcc>=4.9 on linux with i386 def expectedFailureAll(bugnumber=None, oslist=None, compiler=None, compiler_version=None, archs=None, triple=None, debug_info=None, swig_version=None, py_version=None): def fn(self): - oslist_passes = check_decorator_attribute(oslist, self.getPlatform()) - compiler_passes = check_decorator_attribute(self.getCompiler(), compiler) and self.expectedCompilerVersion(compiler_version) + oslist_passes = check_list_or_lambda(oslist, self.getPlatform()) + compiler_passes = check_list_or_lambda(self.getCompiler(), compiler) and self.expectedCompilerVersion(compiler_version) arch_passes = self.expectedArch(archs) triple_passes = triple is None or re.match(triple, lldb.DBG.GetSelectedPlatform().GetTriple()) - debug_info_passes = check_decorator_attribute(debug_info, self.debug_info) + debug_info_passes = check_list_or_lambda(debug_info, self.debug_info) swig_version_passes = (swig_version is None) or (not hasattr(lldb, 'swig_version')) or (check_expected_version(swig_version[0], swig_version[1], lldb.swig_version)) py_version_passes = (py_version is None) or check_expected_version(py_version[0], py_version[1], sys.version_info) @@ -1104,10 +1100,10 @@ def skipIfLinuxClang(func): # TODO: refactor current code, to make skipIfxxx functions to call this function def skipIf(bugnumber=None, oslist=None, compiler=None, compiler_version=None, archs=None, debug_info=None, swig_version=None, py_version=None): def fn(self): - oslist_passes = check_decorator_attribute(oslist, self.getPlatform()) - compiler_passes = check_decorator_attribute(compiler, self.getCompiler()) and self.expectedCompilerVersion(compiler_version) + oslist_passes = oslist is None or self.getPlatform() in oslist + compiler_passes = compiler is None or (compiler in self.getCompiler() and self.expectedCompilerVersion(compiler_version)) arch_passes = self.expectedArch(archs) - debug_info_passes = check_decorator_attribute(debug_info, self.debug_info) + debug_info_passes = debug_info is None or self.debug_info in debug_info swig_version_passes = (swig_version is None) or (not hasattr(lldb, 'swig_version')) or (check_expected_version(swig_version[0], swig_version[1], lldb.swig_version)) py_version_passes = (py_version is None) or check_expected_version(py_version[0], py_version[1], sys.version_info) |