summaryrefslogtreecommitdiff
path: root/tests/test_decorator.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/test_decorator.py')
-rw-r--r--tests/test_decorator.py23
1 files changed, 23 insertions, 0 deletions
diff --git a/tests/test_decorator.py b/tests/test_decorator.py
index b9a1f1e9d..a9a16ba93 100644
--- a/tests/test_decorator.py
+++ b/tests/test_decorator.py
@@ -1,3 +1,4 @@
+import inspect
import unittest
@@ -25,6 +26,28 @@ class TestReify(unittest.TestCase):
result = decorator.__get__(None)
self.assertEqual(result, decorator)
+ def test_copy_docstring(self):
+ def wrapped(inst):
+ """Test doc"""
+ return 'a' # pragma: no cover
+
+ decorator = self._makeOne(wrapped)
+ assert decorator.__doc__ == 'Test doc'
+
+ def test_not_function(self):
+ """
+ Because reify'd methods act as attributes, it's important that they
+ aren't recognized as a function. Otherwise tools like Sphinx may
+ misbehave, like in https://github.com/Pylons/pyramid/issues/3655
+
+ """
+
+ def wrapped(inst):
+ return 'a' # pragma: no cover
+
+ decorator = self._makeOne(wrapped)
+ assert not inspect.isfunction(inspect.unwrap(decorator))
+
class Dummy:
pass