From: Guido van Rossum Date: Fri, 17 Aug 2001 13:40:47 +0000 (+0000) Subject: classic(), methods(): add another test relating to unbound methods: X-Git-Tag: v2.2a3~479 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=93018760bc597f65e8a94c30546eafafd095f170;p=python classic(), methods(): add another test relating to unbound methods: when an unbound method of class A is stored as a class variable of class B, and class B is *not* a subclass of class A, that method should *not* get bound to B instances. --- diff --git a/Lib/test/test_descr.py b/Lib/test/test_descr.py index a26a1e28f4..e40e003486 100644 --- a/Lib/test/test_descr.py +++ b/Lib/test/test_descr.py @@ -760,6 +760,9 @@ def classic(): verify(d.goo(1) == (D, 1)) verify(d.foo(1) == (d, 1)) verify(D.foo(d, 1) == (d, 1)) + class E: # *not* subclassing from C + foo = C.foo + verify(E().foo == C.foo) # i.e., unbound def compattr(): if verbose: print "Testing computed attributes..." @@ -901,6 +904,9 @@ def methods(): verify(d2.foo() == 2) verify(d2.boo() == 2) verify(d2.goo() == 1) + class E(object): + foo = C.foo + verify(E().foo == C.foo) # i.e., unbound def specials(): # Test operators like __hash__ for which a built-in default exists