test_formatters.py
270 lines
| 7.6 KiB
| text/x-python
|
PythonLexer
MinRK
|
r13977 | """Tests for the Formatters.""" | ||
Robert Kern
|
r3209 | |||
MinRK
|
r3350 | from math import pi | ||
try: | ||||
import numpy | ||||
except: | ||||
numpy = None | ||||
Robert Kern
|
r3209 | import nose.tools as nt | ||
MinRK
|
r13977 | from IPython.core.formatters import PlainTextFormatter, HTMLFormatter, _mod_name_key | ||
from IPython.utils.io import capture_output | ||||
Robert Kern
|
r3209 | |||
class A(object): | ||||
def __repr__(self): | ||||
return 'A()' | ||||
class B(A): | ||||
def __repr__(self): | ||||
return 'B()' | ||||
MinRK
|
r13781 | class C: | ||
pass | ||||
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) | ||
Bradley M. Froehle
|
r7875 | nt.assert_equal(f(A()), 'foo') | ||
nt.assert_equal(f(B()), 'foo') | ||||
nt.assert_equal(f(GoodPretty()), 'foo') | ||||
Robert Kern
|
r6268 | # Just don't raise an exception for the following: | ||
f(BadPretty()) | ||||
Robert Kern
|
r3209 | f.pprint = False | ||
Bradley M. Froehle
|
r7875 | nt.assert_equal(f(A()), 'A()') | ||
nt.assert_equal(f(B()), 'B()') | ||||
nt.assert_equal(f(GoodPretty()), 'GoodPretty()') | ||||
Robert Kern
|
r6268 | |||
Robert Kern
|
r3209 | |||
def test_deferred(): | ||||
MinRK
|
r3350 | f = PlainTextFormatter() | ||
def test_precision(): | ||||
"""test various values for float_precision.""" | ||||
f = PlainTextFormatter() | ||||
Bradley M. Froehle
|
r7875 | nt.assert_equal(f(pi), repr(pi)) | ||
MinRK
|
r3350 | f.float_precision = 0 | ||
if numpy: | ||||
po = numpy.get_printoptions() | ||||
Bradley M. Froehle
|
r7875 | nt.assert_equal(po['precision'], 0) | ||
nt.assert_equal(f(pi), '3') | ||||
MinRK
|
r3350 | f.float_precision = 2 | ||
if numpy: | ||||
po = numpy.get_printoptions() | ||||
Bradley M. Froehle
|
r7875 | nt.assert_equal(po['precision'], 2) | ||
nt.assert_equal(f(pi), '3.14') | ||||
MinRK
|
r3350 | f.float_precision = '%g' | ||
if numpy: | ||||
po = numpy.get_printoptions() | ||||
Bradley M. Froehle
|
r7875 | nt.assert_equal(po['precision'], 2) | ||
nt.assert_equal(f(pi), '3.14159') | ||||
MinRK
|
r3350 | f.float_precision = '%e' | ||
Bradley M. Froehle
|
r7875 | nt.assert_equal(f(pi), '3.141593e+00') | ||
MinRK
|
r3350 | f.float_precision = '' | ||
if numpy: | ||||
po = numpy.get_printoptions() | ||||
Bradley M. Froehle
|
r7875 | nt.assert_equal(po['precision'], 8) | ||
nt.assert_equal(f(pi), repr(pi)) | ||||
MinRK
|
r3350 | |||
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) | ||||
MinRK
|
r13655 | def test_for_type(): | ||
f = PlainTextFormatter() | ||||
MinRK
|
r13783 | # initial return, None | ||
nt.assert_is(f.for_type(C, foo_printer), None) | ||||
MinRK
|
r13655 | # no func queries | ||
MinRK
|
r13783 | nt.assert_is(f.for_type(C), foo_printer) | ||
MinRK
|
r13655 | # shouldn't change anything | ||
MinRK
|
r13783 | nt.assert_is(f.for_type(C), foo_printer) | ||
MinRK
|
r13781 | # None should do the same | ||
MinRK
|
r13783 | nt.assert_is(f.for_type(C, None), foo_printer) | ||
nt.assert_is(f.for_type(C, None), foo_printer) | ||||
MinRK
|
r13655 | |||
MinRK
|
r13781 | def test_for_type_string(): | ||
MinRK
|
r13655 | f = PlainTextFormatter() | ||
mod = C.__module__ | ||||
MinRK
|
r13781 | type_str = '%s.%s' % (C.__module__, 'C') | ||
MinRK
|
r13783 | # initial return, None | ||
nt.assert_is(f.for_type(type_str, foo_printer), None) | ||||
MinRK
|
r13781 | # no func queries | ||
MinRK
|
r13783 | nt.assert_is(f.for_type(type_str), foo_printer) | ||
nt.assert_in(_mod_name_key(C), f.deferred_printers) | ||||
nt.assert_is(f.for_type(C), foo_printer) | ||||
nt.assert_not_in(_mod_name_key(C), f.deferred_printers) | ||||
nt.assert_in(C, f.type_printers) | ||||
MinRK
|
r13781 | |||
def test_for_type_by_name(): | ||||
f = PlainTextFormatter() | ||||
mod = C.__module__ | ||||
MinRK
|
r13655 | |||
MinRK
|
r13783 | # initial return, None | ||
nt.assert_is(f.for_type_by_name(mod, 'C', foo_printer), None) | ||||
MinRK
|
r13655 | # no func queries | ||
MinRK
|
r13783 | nt.assert_is(f.for_type_by_name(mod, 'C'), foo_printer) | ||
MinRK
|
r13655 | # shouldn't change anything | ||
MinRK
|
r13783 | nt.assert_is(f.for_type_by_name(mod, 'C'), foo_printer) | ||
MinRK
|
r13781 | # None should do the same | ||
MinRK
|
r13783 | nt.assert_is(f.for_type_by_name(mod, 'C', None), foo_printer) | ||
nt.assert_is(f.for_type_by_name(mod, 'C', None), foo_printer) | ||||
MinRK
|
r13655 | |||
MinRK
|
r13781 | def test_lookup(): | ||
f = PlainTextFormatter() | ||||
MinRK
|
r13783 | f.for_type(C, foo_printer) | ||
nt.assert_is(f.lookup(C()), foo_printer) | ||||
with nt.assert_raises(KeyError): | ||||
f.lookup(A()) | ||||
def test_lookup_string(): | ||||
f = PlainTextFormatter() | ||||
type_str = '%s.%s' % (C.__module__, 'C') | ||||
f.for_type(type_str, foo_printer) | ||||
nt.assert_is(f.lookup(C()), foo_printer) | ||||
# should move from deferred to imported dict | ||||
nt.assert_not_in(_mod_name_key(C), f.deferred_printers) | ||||
nt.assert_in(C, f.type_printers) | ||||
def test_lookup_by_type(): | ||||
f = PlainTextFormatter() | ||||
f.for_type(C, foo_printer) | ||||
nt.assert_is(f.lookup_by_type(C), foo_printer) | ||||
type_str = '%s.%s' % (C.__module__, 'C') | ||||
with nt.assert_raises(KeyError): | ||||
f.lookup_by_type(A) | ||||
def test_lookup_by_type_string(): | ||||
f = PlainTextFormatter() | ||||
type_str = '%s.%s' % (C.__module__, 'C') | ||||
f.for_type(type_str, foo_printer) | ||||
# verify insertion | ||||
nt.assert_in(_mod_name_key(C), f.deferred_printers) | ||||
nt.assert_not_in(C, f.type_printers) | ||||
MinRK
|
r13781 | |||
MinRK
|
r13788 | nt.assert_is(f.lookup_by_type(type_str), foo_printer) | ||
# lookup by string doesn't cause import | ||||
nt.assert_in(_mod_name_key(C), f.deferred_printers) | ||||
nt.assert_not_in(C, f.type_printers) | ||||
MinRK
|
r13783 | nt.assert_is(f.lookup_by_type(C), foo_printer) | ||
# should move from deferred to imported dict | ||||
nt.assert_not_in(_mod_name_key(C), f.deferred_printers) | ||||
nt.assert_in(C, f.type_printers) | ||||
MinRK
|
r13788 | def test_in_formatter(): | ||
f = PlainTextFormatter() | ||||
f.for_type(C, foo_printer) | ||||
type_str = '%s.%s' % (C.__module__, 'C') | ||||
nt.assert_in(C, f) | ||||
nt.assert_in(type_str, f) | ||||
def test_string_in_formatter(): | ||||
f = PlainTextFormatter() | ||||
type_str = '%s.%s' % (C.__module__, 'C') | ||||
f.for_type(type_str, foo_printer) | ||||
nt.assert_in(type_str, f) | ||||
nt.assert_in(C, f) | ||||
MinRK
|
r13783 | def test_pop(): | ||
f = PlainTextFormatter() | ||||
f.for_type(C, foo_printer) | ||||
nt.assert_is(f.lookup_by_type(C), foo_printer) | ||||
MinRK
|
r13788 | nt.assert_is(f.pop(C, None), foo_printer) | ||
f.for_type(C, foo_printer) | ||||
nt.assert_is(f.pop(C), foo_printer) | ||||
MinRK
|
r13783 | with nt.assert_raises(KeyError): | ||
f.lookup_by_type(C) | ||||
with nt.assert_raises(KeyError): | ||||
f.pop(C) | ||||
with nt.assert_raises(KeyError): | ||||
f.pop(A) | ||||
MinRK
|
r13788 | nt.assert_is(f.pop(A, None), None) | ||
MinRK
|
r13783 | |||
def test_pop_string(): | ||||
f = PlainTextFormatter() | ||||
MinRK
|
r13781 | type_str = '%s.%s' % (C.__module__, 'C') | ||
MinRK
|
r13783 | with nt.assert_raises(KeyError): | ||
f.pop(type_str) | ||||
f.for_type(type_str, foo_printer) | ||||
f.pop(type_str) | ||||
with nt.assert_raises(KeyError): | ||||
f.lookup_by_type(C) | ||||
with nt.assert_raises(KeyError): | ||||
f.pop(type_str) | ||||
f.for_type(C, foo_printer) | ||||
MinRK
|
r13788 | nt.assert_is(f.pop(type_str, None), foo_printer) | ||
MinRK
|
r13783 | with nt.assert_raises(KeyError): | ||
f.lookup_by_type(C) | ||||
with nt.assert_raises(KeyError): | ||||
f.pop(type_str) | ||||
MinRK
|
r13788 | nt.assert_is(f.pop(type_str, None), None) | ||
MinRK
|
r13783 | |||
MinRK
|
r13977 | def test_warn_error_method(): | ||
f = HTMLFormatter() | ||||
class BadHTML(object): | ||||
def _repr_html_(self): | ||||
return 1/0 | ||||
bad = BadHTML() | ||||
with capture_output() as captured: | ||||
result = f(bad) | ||||
nt.assert_is(result, None) | ||||
nt.assert_in("WARNING", captured.stderr) | ||||
nt.assert_in("text/html", captured.stderr) | ||||
nt.assert_in("zero", captured.stderr) | ||||
def test_warn_error_for_type(): | ||||
f = HTMLFormatter() | ||||
f.for_type(int, lambda i: name_error) | ||||
with capture_output() as captured: | ||||
result = f(5) | ||||
nt.assert_is(result, None) | ||||
nt.assert_in("WARNING", captured.stderr) | ||||
nt.assert_in("text/html", captured.stderr) | ||||
nt.assert_in("name_error", captured.stderr) | ||||
def test_warn_error_pretty_method(): | ||||
f = PlainTextFormatter() | ||||
class BadPretty(object): | ||||
def _repr_pretty_(self): | ||||
return "hello" | ||||
bad = BadPretty() | ||||
with capture_output() as captured: | ||||
result = f(bad) | ||||
nt.assert_is(result, None) | ||||
nt.assert_in("WARNING", captured.stderr) | ||||
nt.assert_in("text/plain", captured.stderr) | ||||
nt.assert_in("argument", captured.stderr) | ||||
MinRK
|
r13655 | |||