summaryrefslogtreecommitdiffstats
path: root/Lib/test
diff options
context:
space:
mode:
authorBenjamin Peterson <benjamin@python.org>2009-04-15 21:46:14 (GMT)
committerBenjamin Peterson <benjamin@python.org>2009-04-15 21:46:14 (GMT)
commitc843a4765a63098b7cb67a1a38627e39c382d369 (patch)
tree442719abf461eec98e06e5dd2feb2a89c7b6ca06 /Lib/test
parent8b18e2853bac5bf0061ea9ab677e7ae843223ef6 (diff)
downloadcpython-c843a4765a63098b7cb67a1a38627e39c382d369.zip
cpython-c843a4765a63098b7cb67a1a38627e39c382d369.tar.gz
cpython-c843a4765a63098b7cb67a1a38627e39c382d369.tar.bz2
Merged revisions 71627 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r71627 | benjamin.peterson | 2009-04-15 16:26:36 -0500 (Wed, 15 Apr 2009) | 4 lines call __float__ on str subclasses #5759 tests by R. David Murray ........
Diffstat (limited to 'Lib/test')
-rw-r--r--Lib/test/test_float.py12
1 files changed, 12 insertions, 0 deletions
diff --git a/Lib/test/test_float.py b/Lib/test/test_float.py
index 2b6bd78..0b1ae96 100644
--- a/Lib/test/test_float.py
+++ b/Lib/test/test_float.py
@@ -82,11 +82,23 @@ class GeneralFloatCases(unittest.TestCase):
def __float__(self):
return 42
+ # Issue 5759: __float__ not called on str subclasses (though it is on
+ # unicode subclasses).
+ class FooStr(str):
+ def __float__(self):
+ return float(str(self)) + 1
+
+ class FooUnicode(unicode):
+ def __float__(self):
+ return float(unicode(self)) + 1
+
self.assertAlmostEqual(float(Foo0()), 42.)
self.assertAlmostEqual(float(Foo1()), 42.)
self.assertAlmostEqual(float(Foo2()), 42.)
self.assertAlmostEqual(float(Foo3(21)), 42.)
self.assertRaises(TypeError, float, Foo4(42))
+ self.assertAlmostEqual(float(FooUnicode('8')), 9.)
+ self.assertAlmostEqual(float(FooStr('8')), 9.)
def test_floatasratio(self):
for f, ratio in [