Commit 188bdbca authored by Stefan Behnel's avatar Stefan Behnel

disable some f-string formatting tests that give "suboptimal" results in Py2.6

parent 8e1114a0
...@@ -6,9 +6,11 @@ import ast ...@@ -6,9 +6,11 @@ import ast
import types import types
import decimal import decimal
import unittest import unittest
import contextlib
import sys import sys
IS_PY2 = sys.version_info[0] < 3 IS_PY2 = sys.version_info[0] < 3
IS_PY26 = sys.version_info[:2] < (2, 7)
from Cython.Build.Inline import cython_inline from Cython.Build.Inline import cython_inline
from Cython.TestUtils import CythonTest from Cython.TestUtils import CythonTest
...@@ -59,8 +61,23 @@ class TestCase(CythonTest): ...@@ -59,8 +61,23 @@ class TestCase(CythonTest):
first = stripped_first.decode('unicode_escape') first = stripped_first.decode('unicode_escape')
super(TestCase, self).assertEqual(first, second, msg) super(TestCase, self).assertEqual(first, second, msg)
if IS_PY26:
@contextlib.contextmanager
def assertRaises(self, exc):
try:
yield
except exc:
pass
else:
assert False, "exception '%s' not raised" % exc
def assertIn(self, value, collection):
self.assertTrue(value in collection)
def test__format__lookup(self): def test__format__lookup(self):
if IS_PY2: if IS_PY26:
return
elif IS_PY2:
raise unittest.SkipTest("Py3-only") raise unittest.SkipTest("Py3-only")
# Make sure __format__ is looked up on the type, not the instance. # Make sure __format__ is looked up on the type, not the instance.
...@@ -275,6 +292,7 @@ f'{a * x()}'""" ...@@ -275,6 +292,7 @@ f'{a * x()}'"""
width = 10 width = 10
precision = 4 precision = 4
value = decimal.Decimal('12.34567') value = decimal.Decimal('12.34567')
if not IS_PY26:
self.assertEqual(f'result: {value:{width}.{precision}}', 'result: 12.35') self.assertEqual(f'result: {value:{width}.{precision}}', 'result: 12.35')
self.assertEqual(f'result: {value:{width!r}.{precision}}', 'result: 12.35') self.assertEqual(f'result: {value:{width!r}.{precision}}', 'result: 12.35')
self.assertEqual(f'result: {value:{width:0}.{precision:1}}', 'result: 12.35') self.assertEqual(f'result: {value:{width:0}.{precision:1}}', 'result: 12.35')
...@@ -584,6 +602,7 @@ f'{a * x()}'""" ...@@ -584,6 +602,7 @@ f'{a * x()}'"""
def test_conversions(self): def test_conversions(self):
self.assertEqual(f'{3.14:10.10}', ' 3.14') self.assertEqual(f'{3.14:10.10}', ' 3.14')
if not IS_PY26:
self.assertEqual(f'{3.14!s:10.10}', '3.14 ') self.assertEqual(f'{3.14!s:10.10}', '3.14 ')
self.assertEqual(f'{3.14!r:10.10}', '3.14 ') self.assertEqual(f'{3.14!r:10.10}', '3.14 ')
self.assertEqual(f'{3.14!a:10.10}', '3.14 ') self.assertEqual(f'{3.14!a:10.10}', '3.14 ')
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment