Add test.related_bug() to know launchpad bug reports
We(QA-team) have added some tests into Tempest for reproducing bugs on the
gate and applied the corresponding patches into multiple branches. This kind
of tests are useful for production clouds also because they can know latent
bugs of their own clouds from the test failures.
However, it is difficult to find the corresponding patches when facing test
failures now because testers need to search the git history of the failed test
and find the bug number from "Related-Bug" tag from the commit message.
This patch adds a new decorator to know launchpad bug reports more easily.
In addition, this patch puts the decorator to test_delete_attached_volume
as a sample becauuse the test can detect the server internal error which
makes operations harder on productions.
Change-Id: Idc9ac0ebc61e230e4e014fb6476d1c74116511f7
diff --git a/tempest/api/compute/volumes/test_attach_volume_negative.py b/tempest/api/compute/volumes/test_attach_volume_negative.py
index b7fa0fe..1f18bfe 100644
--- a/tempest/api/compute/volumes/test_attach_volume_negative.py
+++ b/tempest/api/compute/volumes/test_attach_volume_negative.py
@@ -29,6 +29,7 @@
             skip_msg = ("%s skipped as Cinder is not available" % cls.__name__)
             raise cls.skipException(skip_msg)
 
+    @test.related_bug('1630783', status_code=500)
     @test.idempotent_id('a313b5cd-fbd0-49cc-94de-870e99f763c7')
     def test_delete_attached_volume(self):
         server = self.create_test_server(wait_until='ACTIVE')
diff --git a/tempest/test.py b/tempest/test.py
index 93fbed3..f5121d8 100644
--- a/tempest/test.py
+++ b/tempest/test.py
@@ -141,6 +141,28 @@
     return False
 
 
+def related_bug(bug, status_code=None):
+    """A decorator useful to know solutions from launchpad bug reports
+
+    @param bug: The launchpad bug number causing the test
+    @param status_code: The status code related to the bug report
+    """
+    def decorator(f):
+        @functools.wraps(f)
+        def wrapper(self, *func_args, **func_kwargs):
+            try:
+                return f(self, *func_args, **func_kwargs)
+            except Exception as exc:
+                exc_status_code = getattr(exc, 'status_code', None)
+                if status_code is None or status_code == exc_status_code:
+                    LOG.error('Hints: This test was made for the bug %s. '
+                              'The failure could be related to '
+                              'https://launchpad.net/bugs/%s' % (bug, bug))
+                raise exc
+        return wrapper
+    return decorator
+
+
 def is_scheduler_filter_enabled(filter_name):
     """Check the list of enabled compute scheduler filters from config. """