test_formatters.py
91 lines
| 2.2 KiB
| text/x-python
|
PythonLexer
Robert Kern
|
r3209 | """Tests for the Formatters. | ||
""" | ||||
MinRK
|
r3350 | from math import pi | ||
try: | ||||
import numpy | ||||
except: | ||||
numpy = None | ||||
Robert Kern
|
r3209 | import nose.tools as nt | ||
MinRK
|
r3350 | from IPython.core.formatters import FormatterABC, PlainTextFormatter | ||
Robert Kern
|
r6268 | from IPython.lib import pretty | ||
Robert Kern
|
r3209 | |||
class A(object): | ||||
def __repr__(self): | ||||
return 'A()' | ||||
class B(A): | ||||
def __repr__(self): | ||||
return 'B()' | ||||
Robert Kern
|
r6268 | class BadPretty(object): | ||
_repr_pretty_ = None | ||||
class GoodPretty(object): | ||||
def _repr_pretty_(self, pp, cycle): | ||||
pp.text('foo') | ||||
def __repr__(self): | ||||
return 'GoodPretty()' | ||||
Robert Kern
|
r3209 | def foo_printer(obj, pp, cycle): | ||
pp.text('foo') | ||||
def test_pretty(): | ||||
MinRK
|
r3350 | f = PlainTextFormatter() | ||
Robert Kern
|
r3209 | f.for_type(A, foo_printer) | ||
nt.assert_equals(f(A()), 'foo') | ||||
nt.assert_equals(f(B()), 'foo') | ||||
Robert Kern
|
r6268 | nt.assert_equals(f(GoodPretty()), 'foo') | ||
# Just don't raise an exception for the following: | ||||
f(BadPretty()) | ||||
Robert Kern
|
r3209 | f.pprint = False | ||
nt.assert_equals(f(A()), 'A()') | ||||
nt.assert_equals(f(B()), 'B()') | ||||
Robert Kern
|
r6268 | nt.assert_equals(f(GoodPretty()), 'GoodPretty()') | ||
Robert Kern
|
r3209 | |||
def test_deferred(): | ||||
MinRK
|
r3350 | f = PlainTextFormatter() | ||
def test_precision(): | ||||
"""test various values for float_precision.""" | ||||
f = PlainTextFormatter() | ||||
nt.assert_equals(f(pi), repr(pi)) | ||||
f.float_precision = 0 | ||||
if numpy: | ||||
po = numpy.get_printoptions() | ||||
nt.assert_equals(po['precision'], 0) | ||||
nt.assert_equals(f(pi), '3') | ||||
f.float_precision = 2 | ||||
if numpy: | ||||
po = numpy.get_printoptions() | ||||
nt.assert_equals(po['precision'], 2) | ||||
nt.assert_equals(f(pi), '3.14') | ||||
f.float_precision = '%g' | ||||
if numpy: | ||||
po = numpy.get_printoptions() | ||||
nt.assert_equals(po['precision'], 2) | ||||
nt.assert_equals(f(pi), '3.14159') | ||||
f.float_precision = '%e' | ||||
nt.assert_equals(f(pi), '3.141593e+00') | ||||
f.float_precision = '' | ||||
if numpy: | ||||
po = numpy.get_printoptions() | ||||
nt.assert_equals(po['precision'], 8) | ||||
nt.assert_equals(f(pi), repr(pi)) | ||||
def test_bad_precision(): | ||||
"""test various invalid values for float_precision.""" | ||||
f = PlainTextFormatter() | ||||
def set_fp(p): | ||||
f.float_precision=p | ||||
nt.assert_raises(ValueError, set_fp, '%') | ||||
nt.assert_raises(ValueError, set_fp, '%.3f%i') | ||||
nt.assert_raises(ValueError, set_fp, 'foo') | ||||
nt.assert_raises(ValueError, set_fp, -1) | ||||
Robert Kern
|
r3209 | |||