123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491 |
- import pprint
- import test.test_support
- import unittest
- import test.test_set
- try:
- uni = unicode
- except NameError:
- def uni(x):
- return x
- # list, tuple and dict subclasses that do or don't overwrite __repr__
- class list2(list):
- pass
- class list3(list):
- def __repr__(self):
- return list.__repr__(self)
- class tuple2(tuple):
- pass
- class tuple3(tuple):
- def __repr__(self):
- return tuple.__repr__(self)
- class set2(set):
- pass
- class set3(set):
- def __repr__(self):
- return set.__repr__(self)
- class frozenset2(frozenset):
- pass
- class frozenset3(frozenset):
- def __repr__(self):
- return frozenset.__repr__(self)
- class dict2(dict):
- pass
- class dict3(dict):
- def __repr__(self):
- return dict.__repr__(self)
- class QueryTestCase(unittest.TestCase):
- def setUp(self):
- self.a = range(100)
- self.b = range(200)
- self.a[-12] = self.b
- def test_basic(self):
- # Verify .isrecursive() and .isreadable() w/o recursion
- pp = pprint.PrettyPrinter()
- for safe in (2, 2.0, 2j, "abc", [3], (2,2), {3: 3}, uni("yaddayadda"),
- bytearray(b"ghi"), True, False, None,
- self.a, self.b):
- # module-level convenience functions
- self.assertFalse(pprint.isrecursive(safe),
- "expected not isrecursive for %r" % (safe,))
- self.assertTrue(pprint.isreadable(safe),
- "expected isreadable for %r" % (safe,))
- # PrettyPrinter methods
- self.assertFalse(pp.isrecursive(safe),
- "expected not isrecursive for %r" % (safe,))
- self.assertTrue(pp.isreadable(safe),
- "expected isreadable for %r" % (safe,))
- def test_knotted(self):
- # Verify .isrecursive() and .isreadable() w/ recursion
- # Tie a knot.
- self.b[67] = self.a
- # Messy dict.
- self.d = {}
- self.d[0] = self.d[1] = self.d[2] = self.d
- pp = pprint.PrettyPrinter()
- for icky in self.a, self.b, self.d, (self.d, self.d):
- self.assertTrue(pprint.isrecursive(icky), "expected isrecursive")
- self.assertFalse(pprint.isreadable(icky), "expected not isreadable")
- self.assertTrue(pp.isrecursive(icky), "expected isrecursive")
- self.assertFalse(pp.isreadable(icky), "expected not isreadable")
- # Break the cycles.
- self.d.clear()
- del self.a[:]
- del self.b[:]
- for safe in self.a, self.b, self.d, (self.d, self.d):
- # module-level convenience functions
- self.assertFalse(pprint.isrecursive(safe),
- "expected not isrecursive for %r" % (safe,))
- self.assertTrue(pprint.isreadable(safe),
- "expected isreadable for %r" % (safe,))
- # PrettyPrinter methods
- self.assertFalse(pp.isrecursive(safe),
- "expected not isrecursive for %r" % (safe,))
- self.assertTrue(pp.isreadable(safe),
- "expected isreadable for %r" % (safe,))
- def test_unreadable(self):
- # Not recursive but not readable anyway
- pp = pprint.PrettyPrinter()
- for unreadable in type(3), pprint, pprint.isrecursive:
- # module-level convenience functions
- self.assertFalse(pprint.isrecursive(unreadable),
- "expected not isrecursive for %r" % (unreadable,))
- self.assertFalse(pprint.isreadable(unreadable),
- "expected not isreadable for %r" % (unreadable,))
- # PrettyPrinter methods
- self.assertFalse(pp.isrecursive(unreadable),
- "expected not isrecursive for %r" % (unreadable,))
- self.assertFalse(pp.isreadable(unreadable),
- "expected not isreadable for %r" % (unreadable,))
- def test_same_as_repr(self):
- # Simple objects, small containers and classes that overwrite __repr__
- # For those the result should be the same as repr().
- # Ahem. The docs don't say anything about that -- this appears to
- # be testing an implementation quirk. Starting in Python 2.5, it's
- # not true for dicts: pprint always sorts dicts by key now; before,
- # it sorted a dict display if and only if the display required
- # multiple lines. For that reason, dicts with more than one element
- # aren't tested here.
- for simple in (0, 0L, 0+0j, 0.0, "", uni(""), bytearray(),
- (), tuple2(), tuple3(),
- [], list2(), list3(),
- set(), set2(), set3(),
- frozenset(), frozenset2(), frozenset3(),
- {}, dict2(), dict3(),
- self.assertTrue, pprint,
- -6, -6L, -6-6j, -1.5, "x", uni("x"), bytearray(b"x"),
- (3,), [3], {3: 6},
- (1,2), [3,4], {5: 6},
- tuple2((1,2)), tuple3((1,2)), tuple3(range(100)),
- [3,4], list2([3,4]), list3([3,4]), list3(range(100)),
- set({7}), set2({7}), set3({7}),
- frozenset({8}), frozenset2({8}), frozenset3({8}),
- dict2({5: 6}), dict3({5: 6}),
- range(10, -11, -1),
- True, False, None,
- ):
- native = repr(simple)
- self.assertEqual(pprint.pformat(simple), native)
- self.assertEqual(pprint.pformat(simple, width=1, indent=0)
- .replace('\n', ' '), native)
- self.assertEqual(pprint.saferepr(simple), native)
- def test_basic_line_wrap(self):
- # verify basic line-wrapping operation
- o = {'RPM_cal': 0,
- 'RPM_cal2': 48059,
- 'Speed_cal': 0,
- 'controldesk_runtime_us': 0,
- 'main_code_runtime_us': 0,
- 'read_io_runtime_us': 0,
- 'write_io_runtime_us': 43690}
- exp = """\
- {'RPM_cal': 0,
- 'RPM_cal2': 48059,
- 'Speed_cal': 0,
- 'controldesk_runtime_us': 0,
- 'main_code_runtime_us': 0,
- 'read_io_runtime_us': 0,
- 'write_io_runtime_us': 43690}"""
- for type in [dict, dict2]:
- self.assertEqual(pprint.pformat(type(o)), exp)
- o = range(100)
- exp = '[%s]' % ',\n '.join(map(str, o))
- for type in [list, list2]:
- self.assertEqual(pprint.pformat(type(o)), exp)
- o = tuple(range(100))
- exp = '(%s)' % ',\n '.join(map(str, o))
- for type in [tuple, tuple2]:
- self.assertEqual(pprint.pformat(type(o)), exp)
- # indent parameter
- o = range(100)
- exp = '[ %s]' % ',\n '.join(map(str, o))
- for type in [list, list2]:
- self.assertEqual(pprint.pformat(type(o), indent=4), exp)
- def test_nested_indentations(self):
- o1 = list(range(10))
- o2 = dict(first=1, second=2, third=3)
- o = [o1, o2]
- expected = """\
- [ [0, 1, 2, 3, 4, 5, 6, 7, 8, 9],
- { 'first': 1,
- 'second': 2,
- 'third': 3}]"""
- self.assertEqual(pprint.pformat(o, indent=4, width=42), expected)
- def test_sorted_dict(self):
- # Starting in Python 2.5, pprint sorts dict displays by key regardless
- # of how small the dictionary may be.
- # Before the change, on 32-bit Windows pformat() gave order
- # 'a', 'c', 'b' here, so this test failed.
- d = {'a': 1, 'b': 1, 'c': 1}
- self.assertEqual(pprint.pformat(d), "{'a': 1, 'b': 1, 'c': 1}")
- self.assertEqual(pprint.pformat([d, d]),
- "[{'a': 1, 'b': 1, 'c': 1}, {'a': 1, 'b': 1, 'c': 1}]")
- # The next one is kind of goofy. The sorted order depends on the
- # alphabetic order of type names: "int" < "str" < "tuple". Before
- # Python 2.5, this was in the test_same_as_repr() test. It's worth
- # keeping around for now because it's one of few tests of pprint
- # against a crazy mix of types.
- self.assertEqual(pprint.pformat({"xy\tab\n": (3,), 5: [[]], (): {}}),
- r"{5: [[]], 'xy\tab\n': (3,), (): {}}")
- def test_subclassing(self):
- o = {'names with spaces': 'should be presented using repr()',
- 'others.should.not.be': 'like.this'}
- exp = """\
- {'names with spaces': 'should be presented using repr()',
- others.should.not.be: like.this}"""
- self.assertEqual(DottedPrettyPrinter().pformat(o), exp)
- def test_set_reprs(self):
- self.assertEqual(pprint.pformat(set()), 'set([])')
- self.assertEqual(pprint.pformat(set(range(3))), 'set([0, 1, 2])')
- self.assertEqual(pprint.pformat(set(range(7)), width=20), '''\
- set([0,
- 1,
- 2,
- 3,
- 4,
- 5,
- 6])''')
- self.assertEqual(pprint.pformat(set2(range(7)), width=20), '''\
- set2([0,
- 1,
- 2,
- 3,
- 4,
- 5,
- 6])''')
- self.assertEqual(pprint.pformat(set3(range(7)), width=20),
- 'set3([0, 1, 2, 3, 4, 5, 6])')
- self.assertEqual(pprint.pformat(frozenset()), 'frozenset([])')
- self.assertEqual(pprint.pformat(frozenset(range(3))),
- 'frozenset([0, 1, 2])')
- self.assertEqual(pprint.pformat(frozenset(range(7)), width=20), '''\
- frozenset([0,
- 1,
- 2,
- 3,
- 4,
- 5,
- 6])''')
- self.assertEqual(pprint.pformat(frozenset2(range(7)), width=20), '''\
- frozenset2([0,
- 1,
- 2,
- 3,
- 4,
- 5,
- 6])''')
- self.assertEqual(pprint.pformat(frozenset3(range(7)), width=20),
- 'frozenset3([0, 1, 2, 3, 4, 5, 6])')
- def test_set_of_sets_reprs(self):
- cube_repr_tgt = """\
- {frozenset([]): frozenset([frozenset([2]), frozenset([0]), frozenset([1])]),
- frozenset([0]): frozenset([frozenset([]),
- frozenset([0, 2]),
- frozenset([0, 1])]),
- frozenset([1]): frozenset([frozenset([]),
- frozenset([1, 2]),
- frozenset([0, 1])]),
- frozenset([2]): frozenset([frozenset([]),
- frozenset([1, 2]),
- frozenset([0, 2])]),
- frozenset([1, 2]): frozenset([frozenset([2]),
- frozenset([1]),
- frozenset([0, 1, 2])]),
- frozenset([0, 2]): frozenset([frozenset([2]),
- frozenset([0]),
- frozenset([0, 1, 2])]),
- frozenset([0, 1]): frozenset([frozenset([0]),
- frozenset([1]),
- frozenset([0, 1, 2])]),
- frozenset([0, 1, 2]): frozenset([frozenset([1, 2]),
- frozenset([0, 2]),
- frozenset([0, 1])])}"""
- cube = test.test_set.cube(3)
- self.assertEqual(pprint.pformat(cube), cube_repr_tgt)
- cubo_repr_tgt = """\
- {frozenset([frozenset([0, 2]), frozenset([0])]): frozenset([frozenset([frozenset([0,
- 2]),
- frozenset([0,
- 1,
- 2])]),
- frozenset([frozenset([0]),
- frozenset([0,
- 1])]),
- frozenset([frozenset([]),
- frozenset([0])]),
- frozenset([frozenset([2]),
- frozenset([0,
- 2])])]),
- frozenset([frozenset([0, 1]), frozenset([1])]): frozenset([frozenset([frozenset([0,
- 1]),
- frozenset([0,
- 1,
- 2])]),
- frozenset([frozenset([0]),
- frozenset([0,
- 1])]),
- frozenset([frozenset([1]),
- frozenset([1,
- 2])]),
- frozenset([frozenset([]),
- frozenset([1])])]),
- frozenset([frozenset([1, 2]), frozenset([1])]): frozenset([frozenset([frozenset([1,
- 2]),
- frozenset([0,
- 1,
- 2])]),
- frozenset([frozenset([2]),
- frozenset([1,
- 2])]),
- frozenset([frozenset([]),
- frozenset([1])]),
- frozenset([frozenset([1]),
- frozenset([0,
- 1])])]),
- frozenset([frozenset([1, 2]), frozenset([2])]): frozenset([frozenset([frozenset([1,
- 2]),
- frozenset([0,
- 1,
- 2])]),
- frozenset([frozenset([1]),
- frozenset([1,
- 2])]),
- frozenset([frozenset([2]),
- frozenset([0,
- 2])]),
- frozenset([frozenset([]),
- frozenset([2])])]),
- frozenset([frozenset([]), frozenset([0])]): frozenset([frozenset([frozenset([0]),
- frozenset([0,
- 1])]),
- frozenset([frozenset([0]),
- frozenset([0,
- 2])]),
- frozenset([frozenset([]),
- frozenset([1])]),
- frozenset([frozenset([]),
- frozenset([2])])]),
- frozenset([frozenset([]), frozenset([1])]): frozenset([frozenset([frozenset([]),
- frozenset([0])]),
- frozenset([frozenset([1]),
- frozenset([1,
- 2])]),
- frozenset([frozenset([]),
- frozenset([2])]),
- frozenset([frozenset([1]),
- frozenset([0,
- 1])])]),
- frozenset([frozenset([2]), frozenset([])]): frozenset([frozenset([frozenset([2]),
- frozenset([1,
- 2])]),
- frozenset([frozenset([]),
- frozenset([0])]),
- frozenset([frozenset([]),
- frozenset([1])]),
- frozenset([frozenset([2]),
- frozenset([0,
- 2])])]),
- frozenset([frozenset([0, 1, 2]), frozenset([0, 1])]): frozenset([frozenset([frozenset([1,
- 2]),
- frozenset([0,
- 1,
- 2])]),
- frozenset([frozenset([0,
- 2]),
- frozenset([0,
- 1,
- 2])]),
- frozenset([frozenset([0]),
- frozenset([0,
- 1])]),
- frozenset([frozenset([1]),
- frozenset([0,
- 1])])]),
- frozenset([frozenset([0]), frozenset([0, 1])]): frozenset([frozenset([frozenset([]),
- frozenset([0])]),
- frozenset([frozenset([0,
- 1]),
- frozenset([0,
- 1,
- 2])]),
- frozenset([frozenset([0]),
- frozenset([0,
- 2])]),
- frozenset([frozenset([1]),
- frozenset([0,
- 1])])]),
- frozenset([frozenset([2]), frozenset([0, 2])]): frozenset([frozenset([frozenset([0,
- 2]),
- frozenset([0,
- 1,
- 2])]),
- frozenset([frozenset([2]),
- frozenset([1,
- 2])]),
- frozenset([frozenset([0]),
- frozenset([0,
- 2])]),
- frozenset([frozenset([]),
- frozenset([2])])]),
- frozenset([frozenset([0, 1, 2]), frozenset([0, 2])]): frozenset([frozenset([frozenset([1,
- 2]),
- frozenset([0,
- 1,
- 2])]),
- frozenset([frozenset([0,
- 1]),
- frozenset([0,
- 1,
- 2])]),
- frozenset([frozenset([0]),
- frozenset([0,
- 2])]),
- frozenset([frozenset([2]),
- frozenset([0,
- 2])])]),
- frozenset([frozenset([1, 2]), frozenset([0, 1, 2])]): frozenset([frozenset([frozenset([0,
- 2]),
- frozenset([0,
- 1,
- 2])]),
- frozenset([frozenset([0,
- 1]),
- frozenset([0,
- 1,
- 2])]),
- frozenset([frozenset([2]),
- frozenset([1,
- 2])]),
- frozenset([frozenset([1]),
- frozenset([1,
- 2])])])}"""
- cubo = test.test_set.linegraph(cube)
- self.assertEqual(pprint.pformat(cubo), cubo_repr_tgt)
- def test_depth(self):
- nested_tuple = (1, (2, (3, (4, (5, 6)))))
- nested_dict = {1: {2: {3: {4: {5: {6: 6}}}}}}
- nested_list = [1, [2, [3, [4, [5, [6, []]]]]]]
- self.assertEqual(pprint.pformat(nested_tuple), repr(nested_tuple))
- self.assertEqual(pprint.pformat(nested_dict), repr(nested_dict))
- self.assertEqual(pprint.pformat(nested_list), repr(nested_list))
- lv1_tuple = '(1, (...))'
- lv1_dict = '{1: {...}}'
- lv1_list = '[1, [...]]'
- self.assertEqual(pprint.pformat(nested_tuple, depth=1), lv1_tuple)
- self.assertEqual(pprint.pformat(nested_dict, depth=1), lv1_dict)
- self.assertEqual(pprint.pformat(nested_list, depth=1), lv1_list)
- class DottedPrettyPrinter(pprint.PrettyPrinter):
- def format(self, object, context, maxlevels, level):
- if isinstance(object, str):
- if ' ' in object:
- return repr(object), 1, 0
- else:
- return object, 0, 0
- else:
- return pprint.PrettyPrinter.format(
- self, object, context, maxlevels, level)
- def test_main():
- test.test_support.run_unittest(QueryTestCase)
- if __name__ == "__main__":
- test_main()
|