]> granicus.if.org Git - python/commitdiff
Rewrite test_order so as to be more "proper". Originally relied on an
authorBrett Cannon <bcannon@gmail.com>
Thu, 19 Aug 2004 03:48:24 +0000 (03:48 +0000)
committerBrett Cannon <bcannon@gmail.com>
Thu, 19 Aug 2004 03:48:24 +0000 (03:48 +0000)
error based on decorating with staticmethod too soon for the code to execute.
This meant that if the test didn't pass it just errored out.  Now if the test
doesn't pass it leads to a failure instead.

Lib/test/test_decorators.py

index c4eb8beb025392676a9dce2bd6c1be16a15f3fdb..56aa5e132338dffd5cb540a4aead3281502c646c 100644 (file)
@@ -191,13 +191,19 @@ class TestDecorators(unittest.TestCase):
         self.assertEqual(C.foo.booh, 42)
 
     def test_order(self):
-        class C(object):
-            @staticmethod
-            @funcattrs(abc=1)
-            def foo(): return 42
-        # This wouldn't work if staticmethod was called first
-        self.assertEqual(C.foo(), 42)
-        self.assertEqual(C().foo(), 42)
+        # Test that decorators are applied in the proper order to the function
+        # they are decorating.
+        def callnum(num):
+            """Decorator factory that returns a decorator that replaces the
+            passed-in function with one that returns the value of 'num'"""
+            def deco(func):
+                return lambda: num
+            return deco
+        @callnum(2)
+        @callnum(1)
+        def foo(): return 42
+        self.assertEqual(foo(), 2,
+                            "Application order of decorators is incorrect")
 
     def test_eval_order(self):
         # Evaluating a decorated function involves four steps for each