From 3a9d43138607e4598d1ce9b24b85b323864f4e68 Mon Sep 17 00:00:00 2001 From: Jonas Devlieghere Date: Fri, 2 Mar 2018 10:38:11 +0000 Subject: [PATCH] [testsuite] Remove workaround for categories and inline tests. Adding categories to inline tests does not work because the attribute is set at the function level. For methods, this means it applies to all instances of that particular class. While this is what we want in most cases, it's not for inline tests, where different instances correspond to different tests. With the workaround in place, assigning a category to one test resulted in the category applied to *all* inline tests. This patch removes the workaround and throws an exception with an informative error message, to prevent this from happening in the future. llvm-svn: 326552 --- lldb/packages/Python/lldbsuite/test/decorators.py | 15 ++++++--------- 1 file changed, 6 insertions(+), 9 deletions(-) diff --git a/lldb/packages/Python/lldbsuite/test/decorators.py b/lldb/packages/Python/lldbsuite/test/decorators.py index 78211e6a84c2..f67681d7a0f6 100644 --- a/lldb/packages/Python/lldbsuite/test/decorators.py +++ b/lldb/packages/Python/lldbsuite/test/decorators.py @@ -304,15 +304,12 @@ def add_test_categories(cat): if isinstance(func, type) and issubclass(func, unittest2.TestCase): raise Exception( "@add_test_categories can only be used to decorate a test method") - - # Update or set the categories attribute. For instance methods, the - # attribute must be set on the actual function. - func_for_attr = func - if inspect.ismethod(func_for_attr): - func_for_attr = func.__func__ - if hasattr(func_for_attr, "categories"): - cat.extend(func_for_attr.categories) - setattr(func_for_attr, "categories", cat) + try: + if hasattr(func, "categories"): + cat.extend(func.categories) + setattr(func, "categories", cat) + except AttributeError: + raise Exception('Cannot assign categories to inline tests.') return func