1 # Python test set -- built-in functions
3 import test
.test_support
, unittest
4 from test
.test_support
import fcmp
, have_unicode
, TESTFN
, unlink
, \
5 run_unittest
, run_with_locale
6 from operator
import neg
8 import sys
, warnings
, cStringIO
, random
, fractions
, UserDict
9 warnings
.filterwarnings("ignore", "hex../oct.. of negative int",
10 FutureWarning
, __name__
)
11 warnings
.filterwarnings("ignore", "integer argument expected",
12 DeprecationWarning, "unittest")
14 # count the number of test runs.
15 # used to skip running test_execfile() multiple times
20 def __init__(self
, max):
24 def __len__(self
): return len(self
.sofar
)
26 def __getitem__(self
, i
):
27 if not 0 <= i
< self
.max: raise IndexError
30 self
.sofar
.append(n
*n
)
36 def __init__(self
, max):
41 return len(self
.sofar
)
43 def __getitem__(self
, i
):
44 if not 0 <= i
< self
.max:
48 self
.sofar
.append(str(n
*n
))
53 def write(self
, line
):
57 class TestFailingBool
:
58 def __nonzero__(self
):
61 class TestFailingIter
:
65 class BuiltinTest(unittest
.TestCase
):
67 def test_import(self
):
71 __import__(name
='sys')
72 __import__(name
='time', level
=0)
73 self
.assertRaises(ImportError, __import__, 'spamspam')
74 self
.assertRaises(TypeError, __import__, 1, 2, 3, 4)
75 self
.assertRaises(ValueError, __import__, '')
76 self
.assertRaises(TypeError, __import__, 'sys', name
='sys')
80 self
.assertEqual(abs(0), 0)
81 self
.assertEqual(abs(1234), 1234)
82 self
.assertEqual(abs(-1234), 1234)
83 self
.assertTrue(abs(-sys
.maxint
-1) > 0)
85 self
.assertEqual(abs(0.0), 0.0)
86 self
.assertEqual(abs(3.14), 3.14)
87 self
.assertEqual(abs(-3.14), 3.14)
89 self
.assertEqual(abs(0L), 0L)
90 self
.assertEqual(abs(1234L), 1234L)
91 self
.assertEqual(abs(-1234L), 1234L)
93 self
.assertRaises(TypeError, abs, 'a')
96 self
.assertEqual(all([2, 4, 6]), True)
97 self
.assertEqual(all([2, None, 6]), False)
98 self
.assertRaises(RuntimeError, all
, [2, TestFailingBool(), 6])
99 self
.assertRaises(RuntimeError, all
, TestFailingIter())
100 self
.assertRaises(TypeError, all
, 10) # Non-iterable
101 self
.assertRaises(TypeError, all
) # No args
102 self
.assertRaises(TypeError, all
, [2, 4, 6], []) # Too many args
103 self
.assertEqual(all([]), True) # Empty iterator
105 self
.assertEqual(all(x
> 42 for x
in S
), True)
107 self
.assertEqual(all(x
> 42 for x
in S
), False)
110 self
.assertEqual(any([None, None, None]), False)
111 self
.assertEqual(any([None, 4, None]), True)
112 self
.assertRaises(RuntimeError, any
, [None, TestFailingBool(), 6])
113 self
.assertRaises(RuntimeError, all
, TestFailingIter())
114 self
.assertRaises(TypeError, any
, 10) # Non-iterable
115 self
.assertRaises(TypeError, any
) # No args
116 self
.assertRaises(TypeError, any
, [2, 4, 6], []) # Too many args
117 self
.assertEqual(any([]), False) # Empty iterator
119 self
.assertEqual(any(x
> 42 for x
in S
), True)
121 self
.assertEqual(any(x
> 42 for x
in S
), False)
125 self
.assertTrue(isinstance(x
, int))
126 self
.assertEqual(-x
, sys
.maxint
+1)
128 def test_apply(self
):
130 self
.assertEqual(args
, ())
132 self
.assertEqual(a1
, 1)
134 self
.assertEqual(a1
, 1)
135 self
.assertEqual(a2
, 2)
137 self
.assertEqual(a1
, 1)
138 self
.assertEqual(a2
, 2)
139 self
.assertEqual(a3
, 3)
145 # A PyCFunction that takes only positional parameters should allow an
146 # empty keyword dictionary to pass without a complaint, but raise a
147 # TypeError if the dictionary is non-empty.
149 self
.assertRaises(TypeError, apply, id, (1,), {"foo": 1})
150 self
.assertRaises(TypeError, apply)
151 self
.assertRaises(TypeError, apply, id, 42)
152 self
.assertRaises(TypeError, apply, id, (42,), 42)
154 def test_callable(self
):
155 self
.assertTrue(callable(len))
157 self
.assertTrue(callable(f
))
160 self
.assertTrue(callable(C
))
162 self
.assertTrue(callable(x
.meth
))
163 self
.assertTrue(not callable(x
))
165 def __call__(self
): pass
167 self
.assertTrue(callable(y
))
171 self
.assertEqual(chr(32), ' ')
172 self
.assertEqual(chr(65), 'A')
173 self
.assertEqual(chr(97), 'a')
174 self
.assertEqual(chr(0xff), '\xff')
175 self
.assertRaises(ValueError, chr, 256)
176 self
.assertRaises(TypeError, chr)
179 self
.assertEqual(cmp(-1, 1), -1)
180 self
.assertEqual(cmp(1, -1), 1)
181 self
.assertEqual(cmp(1, 1), 0)
182 # verify that circular objects are not handled
185 from UserList
import UserList
186 c
= UserList(); c
.append(c
)
187 self
.assertRaises(RuntimeError, cmp, a
, b
)
188 self
.assertRaises(RuntimeError, cmp, b
, c
)
189 self
.assertRaises(RuntimeError, cmp, c
, a
)
190 self
.assertRaises(RuntimeError, cmp, a
, c
)
191 # okay, now break the cycles
192 a
.pop(); b
.pop(); c
.pop()
193 self
.assertRaises(TypeError, cmp)
195 def test_coerce(self
):
196 self
.assertTrue(not fcmp(coerce(1, 1.1), (1.0, 1.1)))
197 self
.assertEqual(coerce(1, 1L), (1L, 1L))
198 self
.assertTrue(not fcmp(coerce(1L, 1.1), (1.0, 1.1)))
199 self
.assertRaises(TypeError, coerce)
201 def __coerce__(self
, other
):
203 self
.assertRaises(ValueError, coerce, 42, BadNumber())
204 self
.assertRaises(OverflowError, coerce, 0.5, int("12345" * 1000))
206 def test_compile(self
):
207 compile('print 1\n', '', 'exec')
209 compile(bom
+ 'print 1\n', '', 'exec')
210 compile(source
='pass', filename
='?', mode
='exec')
211 compile(dont_inherit
=0, filename
='tmp', source
='0', mode
='eval')
212 compile('pass', '?', dont_inherit
=1, mode
='exec')
213 self
.assertRaises(TypeError, compile)
214 self
.assertRaises(ValueError, compile, 'print 42\n', '<string>', 'badmode')
215 self
.assertRaises(ValueError, compile, 'print 42\n', '<string>', 'single', 0xff)
216 self
.assertRaises(TypeError, compile, chr(0), 'f', 'exec')
217 self
.assertRaises(TypeError, compile, 'pass', '?', 'exec',
218 mode
='eval', source
='0', filename
='tmp')
220 compile(unicode('print u"\xc3\xa5"\n', 'utf8'), '', 'exec')
221 self
.assertRaises(TypeError, compile, unichr(0), 'f', 'exec')
222 self
.assertRaises(ValueError, compile, unicode('a = 1'), 'f', 'bad')
225 def test_delattr(self
):
229 self
.assertRaises(TypeError, delattr)
232 # dir(wrong number of arguments)
233 self
.assertRaises(TypeError, dir, 42, 42)
235 # dir() - local scope
237 self
.assertTrue('local_var' in dir())
241 self
.assertTrue('exit' in dir(sys
))
243 # dir(module_with_invalid__dict__)
245 class Foo(types
.ModuleType
):
248 self
.assertRaises(TypeError, dir, f
)
251 self
.assertTrue("strip" in dir(str))
252 self
.assertTrue("__mro__" not in dir(str))
261 self
.assertTrue("y" in dir(f
))
263 # dir(obj_no__dict__)
267 self
.assertTrue("__repr__" in dir(f
))
269 # dir(obj_no__class__with__dict__)
270 # (an ugly trick to cause getattr(f, "__class__") to fail)
272 __slots__
= ["__class__", "__dict__"]
276 self
.assertTrue("__repr__" not in dir(f
))
277 self
.assertTrue("bar" in dir(f
))
279 # dir(obj_using __dir__)
282 return ["kan", "ga", "roo"]
284 self
.assertTrue(dir(f
) == ["ga", "kan", "roo"])
286 # dir(obj__dir__not_list)
291 self
.assertRaises(TypeError, dir, f
)
293 def test_divmod(self
):
294 self
.assertEqual(divmod(12, 7), (1, 5))
295 self
.assertEqual(divmod(-12, 7), (-2, 2))
296 self
.assertEqual(divmod(12, -7), (-2, -2))
297 self
.assertEqual(divmod(-12, -7), (1, -5))
299 self
.assertEqual(divmod(12L, 7L), (1L, 5L))
300 self
.assertEqual(divmod(-12L, 7L), (-2L, 2L))
301 self
.assertEqual(divmod(12L, -7L), (-2L, -2L))
302 self
.assertEqual(divmod(-12L, -7L), (1L, -5L))
304 self
.assertEqual(divmod(12, 7L), (1, 5L))
305 self
.assertEqual(divmod(-12, 7L), (-2, 2L))
306 self
.assertEqual(divmod(12L, -7), (-2L, -2))
307 self
.assertEqual(divmod(-12L, -7), (1L, -5))
309 self
.assertEqual(divmod(-sys
.maxint
-1, -1),
312 self
.assertTrue(not fcmp(divmod(3.25, 1.0), (3.0, 0.25)))
313 self
.assertTrue(not fcmp(divmod(-3.25, 1.0), (-4.0, 0.75)))
314 self
.assertTrue(not fcmp(divmod(3.25, -1.0), (-4.0, -0.75)))
315 self
.assertTrue(not fcmp(divmod(-3.25, -1.0), (3.0, -0.25)))
317 self
.assertRaises(TypeError, divmod)
320 self
.assertEqual(eval('1+1'), 2)
321 self
.assertEqual(eval(' 1+1\n'), 2)
322 globals = {'a': 1, 'b': 2}
323 locals = {'b': 200, 'c': 300}
324 self
.assertEqual(eval('a', globals) , 1)
325 self
.assertEqual(eval('a', globals, locals), 1)
326 self
.assertEqual(eval('b', globals, locals), 200)
327 self
.assertEqual(eval('c', globals, locals), 300)
329 self
.assertEqual(eval(unicode('1+1')), 2)
330 self
.assertEqual(eval(unicode(' 1+1\n')), 2)
331 globals = {'a': 1, 'b': 2}
332 locals = {'b': 200, 'c': 300}
334 self
.assertEqual(eval(unicode('a'), globals), 1)
335 self
.assertEqual(eval(unicode('a'), globals, locals), 1)
336 self
.assertEqual(eval(unicode('b'), globals, locals), 200)
337 self
.assertEqual(eval(unicode('c'), globals, locals), 300)
339 self
.assertEqual(eval(bom
+ 'a', globals, locals), 1)
340 self
.assertEqual(eval(unicode('u"\xc3\xa5"', 'utf8'), globals),
341 unicode('\xc3\xa5', 'utf8'))
342 self
.assertRaises(TypeError, eval)
343 self
.assertRaises(TypeError, eval, ())
345 def test_general_eval(self
):
346 # Tests that general mappings can be used for the locals argument
349 "Test mapping interface versus possible calls from eval()."
350 def __getitem__(self
, key
):
359 self
.assertEqual(eval('a', g
, m
), 12)
360 self
.assertRaises(NameError, eval, 'b', g
, m
)
361 self
.assertEqual(eval('dir()', g
, m
), list('xyz'))
362 self
.assertEqual(eval('globals()', g
, m
), g
)
363 self
.assertEqual(eval('locals()', g
, m
), m
)
364 self
.assertRaises(TypeError, eval, 'a', m
)
369 self
.assertRaises(TypeError, eval, 'a', g
, m
)
371 # Verify that dict subclasses work as well
373 def __getitem__(self
, key
):
376 return dict.__getitem
__(self
, key
)
381 self
.assertEqual(eval('a', g
, d
), 12)
382 self
.assertRaises(NameError, eval, 'b', g
, d
)
383 self
.assertEqual(eval('dir()', g
, d
), list('xyz'))
384 self
.assertEqual(eval('globals()', g
, d
), g
)
385 self
.assertEqual(eval('locals()', g
, d
), d
)
387 # Verify locals stores (used by list comps)
388 eval('[locals() for i in (2,3)]', g
, d
)
389 eval('[locals() for i in (2,3)]', g
, UserDict
.UserDict())
392 "Sample application showing nested, calculated lookups."
394 def __setitem__(self
, key
, formula
):
395 self
._cells
[key
] = formula
396 def __getitem__(self
, key
):
397 return eval(self
._cells
[key
], globals(), self
)
403 self
.assertEqual(ss
['a3'], 210)
405 # Verify that dir() catches a non-list returned by eval
408 def __getitem__(self
, item
):
412 self
.assertRaises(TypeError, eval, 'dir()', globals(), C())
414 # Done outside of the method test_z to get the correct scope
416 f
= open(TESTFN
, 'w')
422 def test_execfile(self
):
428 globals = {'a': 1, 'b': 2}
429 locals = {'b': 200, 'c': 300}
431 self
.assertEqual(self
.__class
__.z
, 2)
433 execfile(TESTFN
, globals)
434 self
.assertEqual(globals['z'], 2)
436 execfile(TESTFN
, globals, locals)
437 self
.assertEqual(locals['z'], 2)
440 "Test mapping interface versus possible calls from execfile()."
443 def __getitem__(self
, key
):
447 def __setitem__(self
, key
, value
):
455 execfile(TESTFN
, globals, locals)
456 self
.assertEqual(locals['z'], 2)
459 self
.assertRaises(TypeError, execfile)
460 self
.assertRaises(TypeError, execfile, TESTFN
, {}, ())
462 self
.assertRaises(IOError, execfile, os
.curdir
)
463 self
.assertRaises(IOError, execfile, "I_dont_exist")
465 def test_filter(self
):
466 self
.assertEqual(filter(lambda c
: 'a' <= c
<= 'z', 'Hello World'), 'elloorld')
467 self
.assertEqual(filter(None, [1, 'hello', [], [3], '', None, 9, 0]), [1, 'hello', [3], 9])
468 self
.assertEqual(filter(lambda x
: x
> 0, [1, -3, 9, 0, 2]), [1, 9, 2])
469 self
.assertEqual(filter(None, Squares(10)), [1, 4, 9, 16, 25, 36, 49, 64, 81])
470 self
.assertEqual(filter(lambda x
: x
%2, Squares(10)), [1, 9, 25, 49, 81])
473 filter(identity
, Squares(5))
474 self
.assertRaises(TypeError, filter)
475 class BadSeq(object):
476 def __getitem__(self
, index
):
480 self
.assertRaises(ValueError, filter, lambda x
: x
, BadSeq())
483 self
.assertRaises(TypeError, filter, badfunc
, range(5))
485 # test bltinmodule.c::filtertuple()
486 self
.assertEqual(filter(None, (1, 2)), (1, 2))
487 self
.assertEqual(filter(lambda x
: x
>=3, (1, 2, 3, 4)), (3, 4))
488 self
.assertRaises(TypeError, filter, 42, (1, 2))
490 # test bltinmodule.c::filterstring()
491 self
.assertEqual(filter(None, "12"), "12")
492 self
.assertEqual(filter(lambda x
: x
>="3", "1234"), "34")
493 self
.assertRaises(TypeError, filter, 42, "12")
495 def __getitem__(self
, index
):
497 self
.assertRaises(ValueError, filter, lambda x
: x
>="3", badstr("1234"))
500 def __getitem__(self
, index
):
502 self
.assertRaises(TypeError, filter, lambda x
: x
>=42, badstr2("1234"))
505 def __getitem__(self
, index
):
506 return weirdstr(2*str.__getitem
__(self
, index
))
507 self
.assertEqual(filter(lambda x
: x
>="33", weirdstr("1234")), "3344")
510 def __getitem__(self
, index
):
511 return chr(ord(str.__getitem
__(self
, index
))+1)
512 self
.assertEqual(filter(lambda x
: x
>="3", shiftstr("1234")), "345")
515 # test bltinmodule.c::filterunicode()
516 self
.assertEqual(filter(None, unicode("12")), unicode("12"))
517 self
.assertEqual(filter(lambda x
: x
>="3", unicode("1234")), unicode("34"))
518 self
.assertRaises(TypeError, filter, 42, unicode("12"))
519 self
.assertRaises(ValueError, filter, lambda x
: x
>="3", badstr(unicode("1234")))
521 class badunicode(unicode):
522 def __getitem__(self
, index
):
524 self
.assertRaises(TypeError, filter, lambda x
: x
>=42, badunicode("1234"))
526 class weirdunicode(unicode):
527 def __getitem__(self
, index
):
528 return weirdunicode(2*unicode.__getitem
__(self
, index
))
530 filter(lambda x
: x
>=unicode("33"), weirdunicode("1234")), unicode("3344"))
532 class shiftunicode(unicode):
533 def __getitem__(self
, index
):
534 return unichr(ord(unicode.__getitem
__(self
, index
))+1)
536 filter(lambda x
: x
>=unicode("3"), shiftunicode("1234")),
540 def test_filter_subclasses(self
):
541 # test that filter() never returns tuple, str or unicode subclasses
542 # and that the result always goes through __getitem__
543 funcs
= (None, bool, lambda x
: True)
545 def __getitem__(self
, index
):
546 return 2*tuple.__getitem
__(self
, index
)
548 def __getitem__(self
, index
):
549 return 2*str.__getitem
__(self
, index
)
551 tuple2
: {(): (), (1, 2, 3): (2, 4, 6)},
552 str2
: {"": "", "123": "112233"}
555 class unicode2(unicode):
556 def __getitem__(self
, index
):
557 return 2*unicode.__getitem
__(self
, index
)
559 unicode(): unicode(),
560 unicode("123"): unicode("112233")
563 for (cls
, inps
) in inputs
.iteritems():
564 for (inp
, exp
) in inps
.iteritems():
565 # make sure the output goes through __getitem__
566 # even if func is None
568 filter(funcs
[0], cls(inp
)),
569 filter(funcs
[1], cls(inp
))
572 outp
= filter(func
, cls(inp
))
573 self
.assertEqual(outp
, exp
)
574 self
.assertTrue(not isinstance(outp
, cls
))
576 def test_getattr(self
):
578 self
.assertTrue(getattr(sys
, 'stdout') is sys
.stdout
)
579 self
.assertRaises(TypeError, getattr, sys
, 1)
580 self
.assertRaises(TypeError, getattr, sys
, 1, "foo")
581 self
.assertRaises(TypeError, getattr)
583 self
.assertRaises(UnicodeError, getattr, sys
, unichr(sys
.maxunicode
))
585 def test_hasattr(self
):
587 self
.assertTrue(hasattr(sys
, 'stdout'))
588 self
.assertRaises(TypeError, hasattr, sys
, 1)
589 self
.assertRaises(TypeError, hasattr)
591 self
.assertRaises(UnicodeError, hasattr, sys
, unichr(sys
.maxunicode
))
593 # Check that hasattr allows SystemExit and KeyboardInterrupts by
595 def __getattr__(self
, what
):
596 raise KeyboardInterrupt
597 self
.assertRaises(KeyboardInterrupt, hasattr, A(), "b")
599 def __getattr__(self
, what
):
601 self
.assertRaises(SystemExit, hasattr, B(), "b")
605 self
.assertEqual(hash(1), hash(1L))
606 self
.assertEqual(hash(1), hash(1.0))
609 self
.assertEqual(hash('spam'), hash(unicode('spam')))
612 self
.assertRaises(TypeError, hash, [])
613 self
.assertRaises(TypeError, hash, {})
614 # Bug 1536021: Allow hash to return long objects
618 self
.assertEquals(type(hash(X())), int)
622 self
.assertEquals(type(hash(Y())), int)
626 self
.assertEquals(hash(Z(42)), hash(42L))
629 self
.assertEqual(hex(16), '0x10')
630 self
.assertEqual(hex(16L), '0x10L')
631 self
.assertEqual(hex(-16), '-0x10')
632 self
.assertEqual(hex(-16L), '-0x10L')
633 self
.assertRaises(TypeError, hex, {})
643 id({'spam': 1, 'eggs': 2, 'ham': 3})
645 # Test input() later, together with raw_input
647 def test_intern(self
):
648 self
.assertRaises(TypeError, intern)
649 s
= "never interned before"
650 self
.assertTrue(intern(s
) is s
)
651 s2
= s
.swapcase().swapcase()
652 self
.assertTrue(intern(s2
) is s
)
654 # Subclasses of string can't be interned, because they
655 # provide too much opportunity for insane things to happen.
656 # We don't want them in the interned dict and if they aren't
657 # actually interned, we don't want to create the appearance
658 # that they are by allowing intern() to succeeed.
663 self
.assertRaises(TypeError, intern, S("abc"))
665 # It's still safe to pass these strings to routines that
666 # call intern internally, e.g. PyObject_SetAttr().
669 self
.assertEqual(getattr(s
, s
), s
)
672 self
.assertRaises(TypeError, iter)
673 self
.assertRaises(TypeError, iter, 42, 42)
674 lists
= [("1", "2"), ["1", "2"], "12"]
676 lists
.append(unicode("12"))
679 self
.assertEqual(i
.next(), '1')
680 self
.assertEqual(i
.next(), '2')
681 self
.assertRaises(StopIteration, i
.next
)
683 def test_isinstance(self
):
693 self
.assertTrue(isinstance(c
, C
))
694 self
.assertTrue(isinstance(d
, C
))
695 self
.assertTrue(not isinstance(e
, C
))
696 self
.assertTrue(not isinstance(c
, D
))
697 self
.assertTrue(not isinstance('foo', E
))
698 self
.assertRaises(TypeError, isinstance, E
, 'foo')
699 self
.assertRaises(TypeError, isinstance)
701 def test_issubclass(self
):
711 self
.assertTrue(issubclass(D
, C
))
712 self
.assertTrue(issubclass(C
, C
))
713 self
.assertTrue(not issubclass(C
, D
))
714 self
.assertRaises(TypeError, issubclass, 'foo', E
)
715 self
.assertRaises(TypeError, issubclass, E
, 'foo')
716 self
.assertRaises(TypeError, issubclass)
719 self
.assertEqual(len('123'), 3)
720 self
.assertEqual(len(()), 0)
721 self
.assertEqual(len((1, 2, 3, 4)), 4)
722 self
.assertEqual(len([1, 2, 3, 4]), 4)
723 self
.assertEqual(len({}), 0)
724 self
.assertEqual(len({'a':1, 'b': 2}), 2)
728 self
.assertRaises(ValueError, len, BadSeq())
732 map(None, 'hello world'),
733 ['h','e','l','l','o',' ','w','o','r','l','d']
736 map(None, 'abcd', 'efg'),
737 [('a', 'e'), ('b', 'f'), ('c', 'g'), ('d', None)]
740 map(None, range(10)),
741 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
744 map(lambda x
: x
*x
, range(1,4)),
748 from math
import sqrt
753 map(lambda x
: map(sqrt
,x
), [[16, 4], [81, 9]]),
754 [[4.0, 2.0], [9.0, 3.0]]
757 map(lambda x
, y
: x
+y
, [1,3,2], [9,1,4]),
763 for i
in v
: accu
= accu
+ i
766 map(plus
, [1, 3, 7]),
770 map(plus
, [1, 3, 7], [4, 9, 2]),
774 map(plus
, [1, 3, 7], [4, 9, 2], [1, 1, 0]),
775 [1+4+1, 3+9+1, 7+2+0]
778 map(None, Squares(10)),
779 [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
782 map(int, Squares(10)),
783 [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
786 map(None, Squares(3), Squares(2)),
787 [(0,0), (1,1), (4,None)]
790 map(max, Squares(3), Squares(2)),
793 self
.assertRaises(TypeError, map)
794 self
.assertRaises(TypeError, map, lambda x
: x
, 42)
795 self
.assertEqual(map(None, [42]), [42])
797 def __getitem__(self
, index
):
799 self
.assertRaises(ValueError, map, lambda x
: x
, BadSeq())
802 self
.assertRaises(RuntimeError, map, badfunc
, range(5))
805 self
.assertEqual(max('123123'), '3')
806 self
.assertEqual(max(1, 2, 3), 3)
807 self
.assertEqual(max((1, 2, 3, 1, 2, 3)), 3)
808 self
.assertEqual(max([1, 2, 3, 1, 2, 3]), 3)
810 self
.assertEqual(max(1, 2L, 3.0), 3.0)
811 self
.assertEqual(max(1L, 2.0, 3), 3)
812 self
.assertEqual(max(1.0, 2, 3L), 3L)
815 "max(key=int)", # no args
816 "max(1, key=int)", # single arg not iterable
817 "max(1, 2, keystone=int)", # wrong keyword
818 "max(1, 2, key=int, abc=int)", # two many keywords
819 "max(1, 2, key=1)", # keyfunc is not callable
822 exec(stmt
) in globals()
828 self
.assertEqual(max((1,), key
=neg
), 1) # one elem iterable
829 self
.assertEqual(max((1,2), key
=neg
), 1) # two elem iterable
830 self
.assertEqual(max(1, 2, key
=neg
), 1) # two elems
832 data
= [random
.randrange(200) for i
in range(100)]
833 keys
= dict((elem
, random
.randrange(50)) for elem
in data
)
835 self
.assertEqual(max(data
, key
=f
),
836 sorted(reversed(data
), key
=f
)[-1])
839 self
.assertEqual(min('123123'), '1')
840 self
.assertEqual(min(1, 2, 3), 1)
841 self
.assertEqual(min((1, 2, 3, 1, 2, 3)), 1)
842 self
.assertEqual(min([1, 2, 3, 1, 2, 3]), 1)
844 self
.assertEqual(min(1, 2L, 3.0), 1)
845 self
.assertEqual(min(1L, 2.0, 3), 1L)
846 self
.assertEqual(min(1.0, 2, 3L), 1.0)
848 self
.assertRaises(TypeError, min)
849 self
.assertRaises(TypeError, min, 42)
850 self
.assertRaises(ValueError, min, ())
852 def __getitem__(self
, index
):
854 self
.assertRaises(ValueError, min, BadSeq())
856 def __cmp__(self
, other
):
858 self
.assertRaises(ValueError, min, (42, BadNumber()))
861 "min(key=int)", # no args
862 "min(1, key=int)", # single arg not iterable
863 "min(1, 2, keystone=int)", # wrong keyword
864 "min(1, 2, key=int, abc=int)", # two many keywords
865 "min(1, 2, key=1)", # keyfunc is not callable
868 exec(stmt
) in globals()
874 self
.assertEqual(min((1,), key
=neg
), 1) # one elem iterable
875 self
.assertEqual(min((1,2), key
=neg
), 2) # two elem iterable
876 self
.assertEqual(min(1, 2, key
=neg
), 2) # two elems
878 data
= [random
.randrange(200) for i
in range(100)]
879 keys
= dict((elem
, random
.randrange(50)) for elem
in data
)
881 self
.assertEqual(min(data
, key
=f
),
882 sorted(data
, key
=f
)[0])
886 self
.assertEqual(next(it
), 0)
887 self
.assertEqual(next(it
), 1)
888 self
.assertRaises(StopIteration, next
, it
)
889 self
.assertRaises(StopIteration, next
, it
)
890 self
.assertEquals(next(it
, 42), 42)
899 self
.assertEquals(next(it
, 42), 42)
900 self
.assertRaises(StopIteration, next
, it
)
907 self
.assertEquals(next(it
), 1)
908 self
.assertRaises(StopIteration, next
, it
)
909 self
.assertEquals(next(it
, 42), 42)
912 self
.assertEqual(oct(100), '0144')
913 self
.assertEqual(oct(100L), '0144L')
914 self
.assertEqual(oct(-100), '-0144')
915 self
.assertEqual(oct(-100L), '-0144L')
916 self
.assertRaises(TypeError, oct, ())
918 def write_testfile(self
):
919 # NB the first 4 lines are also used to test input and raw_input, below
920 fp
= open(TESTFN
, 'w')
924 fp
.write('The quick brown fox jumps over the lazy dog')
926 fp
.write('Dear John\n')
933 self
.write_testfile()
934 fp
= open(TESTFN
, 'r')
936 self
.assertEqual(fp
.readline(4), '1+1\n')
937 self
.assertEqual(fp
.readline(4), '1+1\n')
938 self
.assertEqual(fp
.readline(), 'The quick brown fox jumps over the lazy dog.\n')
939 self
.assertEqual(fp
.readline(4), 'Dear')
940 self
.assertEqual(fp
.readline(100), ' John\n')
941 self
.assertEqual(fp
.read(300), 'XXX'*100)
942 self
.assertEqual(fp
.read(1000), 'YYY'*100)
948 self
.assertEqual(ord(' '), 32)
949 self
.assertEqual(ord('A'), 65)
950 self
.assertEqual(ord('a'), 97)
952 self
.assertEqual(ord(unichr(sys
.maxunicode
)), sys
.maxunicode
)
953 self
.assertRaises(TypeError, ord, 42)
955 self
.assertRaises(TypeError, ord, unicode("12"))
958 self
.assertEqual(pow(0,0), 1)
959 self
.assertEqual(pow(0,1), 0)
960 self
.assertEqual(pow(1,0), 1)
961 self
.assertEqual(pow(1,1), 1)
963 self
.assertEqual(pow(2,0), 1)
964 self
.assertEqual(pow(2,10), 1024)
965 self
.assertEqual(pow(2,20), 1024*1024)
966 self
.assertEqual(pow(2,30), 1024*1024*1024)
968 self
.assertEqual(pow(-2,0), 1)
969 self
.assertEqual(pow(-2,1), -2)
970 self
.assertEqual(pow(-2,2), 4)
971 self
.assertEqual(pow(-2,3), -8)
973 self
.assertEqual(pow(0L,0), 1)
974 self
.assertEqual(pow(0L,1), 0)
975 self
.assertEqual(pow(1L,0), 1)
976 self
.assertEqual(pow(1L,1), 1)
978 self
.assertEqual(pow(2L,0), 1)
979 self
.assertEqual(pow(2L,10), 1024)
980 self
.assertEqual(pow(2L,20), 1024*1024)
981 self
.assertEqual(pow(2L,30), 1024*1024*1024)
983 self
.assertEqual(pow(-2L,0), 1)
984 self
.assertEqual(pow(-2L,1), -2)
985 self
.assertEqual(pow(-2L,2), 4)
986 self
.assertEqual(pow(-2L,3), -8)
988 self
.assertAlmostEqual(pow(0.,0), 1.)
989 self
.assertAlmostEqual(pow(0.,1), 0.)
990 self
.assertAlmostEqual(pow(1.,0), 1.)
991 self
.assertAlmostEqual(pow(1.,1), 1.)
993 self
.assertAlmostEqual(pow(2.,0), 1.)
994 self
.assertAlmostEqual(pow(2.,10), 1024.)
995 self
.assertAlmostEqual(pow(2.,20), 1024.*1024.)
996 self
.assertAlmostEqual(pow(2.,30), 1024.*1024.*1024.)
998 self
.assertAlmostEqual(pow(-2.,0), 1.)
999 self
.assertAlmostEqual(pow(-2.,1), -2.)
1000 self
.assertAlmostEqual(pow(-2.,2), 4.)
1001 self
.assertAlmostEqual(pow(-2.,3), -8.)
1003 for x
in 2, 2L, 2.0:
1004 for y
in 10, 10L, 10.0:
1005 for z
in 1000, 1000L, 1000.0:
1006 if isinstance(x
, float) or \
1007 isinstance(y
, float) or \
1008 isinstance(z
, float):
1009 self
.assertRaises(TypeError, pow, x
, y
, z
)
1011 self
.assertAlmostEqual(pow(x
, y
, z
), 24.0)
1013 self
.assertRaises(TypeError, pow, -1, -2, 3)
1014 self
.assertRaises(ValueError, pow, 1, 2, 0)
1015 self
.assertRaises(TypeError, pow, -1L, -2L, 3L)
1016 self
.assertRaises(ValueError, pow, 1L, 2L, 0L)
1017 # Will return complex in 3.0:
1018 self
.assertRaises(ValueError, pow, -342.43, 0.234)
1020 self
.assertRaises(TypeError, pow)
1022 def test_range(self
):
1023 self
.assertEqual(range(3), [0, 1, 2])
1024 self
.assertEqual(range(1, 5), [1, 2, 3, 4])
1025 self
.assertEqual(range(0), [])
1026 self
.assertEqual(range(-3), [])
1027 self
.assertEqual(range(1, 10, 3), [1, 4, 7])
1028 self
.assertEqual(range(5, -5, -3), [5, 2, -1, -4])
1030 # Now test range() with longs
1031 self
.assertEqual(range(-2**100), [])
1032 self
.assertEqual(range(0, -2**100), [])
1033 self
.assertEqual(range(0, 2**100, -1), [])
1034 self
.assertEqual(range(0, 2**100, -1), [])
1036 a
= long(10 * sys
.maxint
)
1037 b
= long(100 * sys
.maxint
)
1038 c
= long(50 * sys
.maxint
)
1040 self
.assertEqual(range(a
, a
+2), [a
, a
+1])
1041 self
.assertEqual(range(a
+2, a
, -1L), [a
+2, a
+1])
1042 self
.assertEqual(range(a
+4, a
, -2), [a
+4, a
+2])
1044 seq
= range(a
, b
, c
)
1045 self
.assertTrue(a
in seq
)
1046 self
.assertTrue(b
not in seq
)
1047 self
.assertEqual(len(seq
), 2)
1049 seq
= range(b
, a
, -c
)
1050 self
.assertTrue(b
in seq
)
1051 self
.assertTrue(a
not in seq
)
1052 self
.assertEqual(len(seq
), 2)
1054 seq
= range(-a
, -b
, -c
)
1055 self
.assertTrue(-a
in seq
)
1056 self
.assertTrue(-b
not in seq
)
1057 self
.assertEqual(len(seq
), 2)
1059 self
.assertRaises(TypeError, range)
1060 self
.assertRaises(TypeError, range, 1, 2, 3, 4)
1061 self
.assertRaises(ValueError, range, 1, 2, 0)
1062 self
.assertRaises(ValueError, range, a
, a
+ 1, long(0))
1065 def __cmp__(self
, other
):
1067 __hash__
= None # Invalid cmp makes this unhashable
1068 self
.assertRaises(RuntimeError, range, a
, a
+ 1, badzero(1))
1070 # Reject floats when it would require PyLongs to represent.
1071 # (smaller floats still accepted, but deprecated)
1072 self
.assertRaises(TypeError, range, 1e100
, 1e101
, 1e101
)
1074 self
.assertRaises(TypeError, range, 0, "spam")
1075 self
.assertRaises(TypeError, range, 0, 42, "spam")
1077 self
.assertRaises(OverflowError, range, -sys
.maxint
, sys
.maxint
)
1078 self
.assertRaises(OverflowError, range, 0, 2*sys
.maxint
)
1080 def test_input_and_raw_input(self
):
1081 self
.write_testfile()
1082 fp
= open(TESTFN
, 'r')
1083 savestdin
= sys
.stdin
1084 savestdout
= sys
.stdout
# Eats the echo
1087 sys
.stdout
= BitBucket()
1088 self
.assertEqual(input(), 2)
1089 self
.assertEqual(input('testing\n'), 2)
1090 self
.assertEqual(raw_input(), 'The quick brown fox jumps over the lazy dog.')
1091 self
.assertEqual(raw_input('testing\n'), 'Dear John')
1093 # SF 1535165: don't segfault on closed stdin
1094 # sys.stdout must be a regular file for triggering
1095 sys
.stdout
= savestdout
1097 self
.assertRaises(ValueError, input)
1099 sys
.stdout
= BitBucket()
1100 sys
.stdin
= cStringIO
.StringIO("NULL\0")
1101 self
.assertRaises(TypeError, input, 42, 42)
1102 sys
.stdin
= cStringIO
.StringIO(" 'whitespace'")
1103 self
.assertEqual(input(), 'whitespace')
1104 sys
.stdin
= cStringIO
.StringIO()
1105 self
.assertRaises(EOFError, input)
1107 # SF 876178: make sure input() respect future options.
1108 sys
.stdin
= cStringIO
.StringIO('1/2')
1109 sys
.stdout
= cStringIO
.StringIO()
1110 exec compile('print input()', 'test_builtin_tmp', 'exec')
1111 sys
.stdin
.seek(0, 0)
1112 exec compile('from __future__ import division;print input()',
1113 'test_builtin_tmp', 'exec')
1114 sys
.stdin
.seek(0, 0)
1115 exec compile('print input()', 'test_builtin_tmp', 'exec')
1116 # The result we expect depends on whether new division semantics
1117 # are already in effect.
1119 # This test was compiled with old semantics.
1120 expected
= ['0', '0.5', '0']
1122 # This test was compiled with new semantics (e.g., -Qnew
1123 # was given on the command line.
1124 expected
= ['0.5', '0.5', '0.5']
1125 self
.assertEqual(sys
.stdout
.getvalue().splitlines(), expected
)
1128 self
.assertRaises(RuntimeError, input, 'prompt')
1130 self
.assertRaises(RuntimeError, input, 'prompt')
1132 sys
.stdin
= savestdin
1133 sys
.stdout
= savestdout
1137 def test_reduce(self
):
1138 self
.assertEqual(reduce(lambda x
, y
: x
+y
, ['a', 'b', 'c'], ''), 'abc')
1140 reduce(lambda x
, y
: x
+y
, [['a', 'c'], [], ['d', 'w']], []),
1143 self
.assertEqual(reduce(lambda x
, y
: x
*y
, range(2,8), 1), 5040)
1145 reduce(lambda x
, y
: x
*y
, range(2,21), 1L),
1146 2432902008176640000L
1148 self
.assertEqual(reduce(lambda x
, y
: x
+y
, Squares(10)), 285)
1149 self
.assertEqual(reduce(lambda x
, y
: x
+y
, Squares(10), 0), 285)
1150 self
.assertEqual(reduce(lambda x
, y
: x
+y
, Squares(0), 0), 0)
1151 self
.assertRaises(TypeError, reduce)
1152 self
.assertRaises(TypeError, reduce, 42, 42)
1153 self
.assertRaises(TypeError, reduce, 42, 42, 42)
1154 self
.assertEqual(reduce(42, "1"), "1") # func is never called with one item
1155 self
.assertEqual(reduce(42, "", "1"), "1") # func is never called with one item
1156 self
.assertRaises(TypeError, reduce, 42, (42, 42))
1159 def __getitem__(self
, index
):
1161 self
.assertRaises(ValueError, reduce, 42, BadSeq())
1163 def test_reload(self
):
1169 ## self.assertRaises(ImportError, reload, sys)
1171 def test_repr(self
):
1172 self
.assertEqual(repr(''), '\'\'')
1173 self
.assertEqual(repr(0), '0')
1174 self
.assertEqual(repr(0L), '0L')
1175 self
.assertEqual(repr(()), '()')
1176 self
.assertEqual(repr([]), '[]')
1177 self
.assertEqual(repr({}), '{}')
1180 self
.assertEqual(repr(a
), '[[...]]')
1183 self
.assertEqual(repr(a
), '{0: {...}}')
1185 def test_round(self
):
1186 self
.assertEqual(round(0.0), 0.0)
1187 self
.assertEqual(type(round(0.0)), float) # Will be int in 3.0.
1188 self
.assertEqual(round(1.0), 1.0)
1189 self
.assertEqual(round(10.0), 10.0)
1190 self
.assertEqual(round(1000000000.0), 1000000000.0)
1191 self
.assertEqual(round(1e20
), 1e20
)
1193 self
.assertEqual(round(-1.0), -1.0)
1194 self
.assertEqual(round(-10.0), -10.0)
1195 self
.assertEqual(round(-1000000000.0), -1000000000.0)
1196 self
.assertEqual(round(-1e20
), -1e20
)
1198 self
.assertEqual(round(0.1), 0.0)
1199 self
.assertEqual(round(1.1), 1.0)
1200 self
.assertEqual(round(10.1), 10.0)
1201 self
.assertEqual(round(1000000000.1), 1000000000.0)
1203 self
.assertEqual(round(-1.1), -1.0)
1204 self
.assertEqual(round(-10.1), -10.0)
1205 self
.assertEqual(round(-1000000000.1), -1000000000.0)
1207 self
.assertEqual(round(0.9), 1.0)
1208 self
.assertEqual(round(9.9), 10.0)
1209 self
.assertEqual(round(999999999.9), 1000000000.0)
1211 self
.assertEqual(round(-0.9), -1.0)
1212 self
.assertEqual(round(-9.9), -10.0)
1213 self
.assertEqual(round(-999999999.9), -1000000000.0)
1215 self
.assertEqual(round(-8.0, -1), -10.0)
1216 self
.assertEqual(type(round(-8.0, -1)), float)
1218 self
.assertEqual(type(round(-8.0, 0)), float)
1219 self
.assertEqual(type(round(-8.0, 1)), float)
1221 # Check half rounding behaviour.
1222 self
.assertEqual(round(5.5), 6)
1223 self
.assertEqual(round(6.5), 7)
1224 self
.assertEqual(round(-5.5), -6)
1225 self
.assertEqual(round(-6.5), -7)
1227 # Issue #1869: integral floats should remain unchanged
1228 self
.assertEqual(round(5e15
+1), 5e15
+1)
1230 # Check behavior on ints
1231 self
.assertEqual(round(0), 0)
1232 self
.assertEqual(round(8), 8)
1233 self
.assertEqual(round(-8), -8)
1234 self
.assertEqual(type(round(0)), float) # Will be int in 3.0.
1235 self
.assertEqual(type(round(-8, -1)), float)
1236 self
.assertEqual(type(round(-8, 0)), float)
1237 self
.assertEqual(type(round(-8, 1)), float)
1240 self
.assertEqual(round(number
=-8.0, ndigits
=-1), -10.0)
1242 self
.assertRaises(TypeError, round)
1244 # test generic rounding delegation for reals
1245 class TestRound(object):
1246 def __float__(self
):
1249 class TestNoRound(object):
1252 self
.assertEqual(round(TestRound()), 23)
1254 self
.assertRaises(TypeError, round, 1, 2, 3)
1255 self
.assertRaises(TypeError, round, TestNoRound())
1258 t
.__float
__ = lambda *args
: args
1259 self
.assertRaises(TypeError, round, t
)
1260 self
.assertRaises(TypeError, round, t
, 0)
1262 def test_setattr(self
):
1263 setattr(sys
, 'spam', 1)
1264 self
.assertEqual(sys
.spam
, 1)
1265 self
.assertRaises(TypeError, setattr, sys
, 1, 'spam')
1266 self
.assertRaises(TypeError, setattr)
1269 self
.assertEqual(sum([]), 0)
1270 self
.assertEqual(sum(range(2,8)), 27)
1271 self
.assertEqual(sum(iter(range(2,8))), 27)
1272 self
.assertEqual(sum(Squares(10)), 285)
1273 self
.assertEqual(sum(iter(Squares(10))), 285)
1274 self
.assertEqual(sum([[1], [2], [3]], []), [1, 2, 3])
1276 self
.assertRaises(TypeError, sum)
1277 self
.assertRaises(TypeError, sum, 42)
1278 self
.assertRaises(TypeError, sum, ['a', 'b', 'c'])
1279 self
.assertRaises(TypeError, sum, ['a', 'b', 'c'], '')
1280 self
.assertRaises(TypeError, sum, [[1], [2], [3]])
1281 self
.assertRaises(TypeError, sum, [{2:3}])
1282 self
.assertRaises(TypeError, sum, [{2:3}]*2, {2:3})
1285 def __getitem__(self
, index
):
1287 self
.assertRaises(ValueError, sum, BadSeq())
1290 sum(([x
] for x
in range(10)), empty
)
1291 self
.assertEqual(empty
, [])
1293 def test_type(self
):
1294 self
.assertEqual(type(''), type('123'))
1295 self
.assertNotEqual(type(''), type(()))
1297 def test_unichr(self
):
1299 self
.assertEqual(unichr(32), unicode(' '))
1300 self
.assertEqual(unichr(65), unicode('A'))
1301 self
.assertEqual(unichr(97), unicode('a'))
1303 unichr(sys
.maxunicode
),
1304 unicode('\\U%08x' % (sys
.maxunicode
), 'unicode-escape')
1306 self
.assertRaises(ValueError, unichr, sys
.maxunicode
+1)
1307 self
.assertRaises(TypeError, unichr)
1308 self
.assertRaises((OverflowError, ValueError), unichr, 2**32)
1310 # We don't want self in vars(), so these are static methods
1318 BuiltinTest
.get_vars_f0()
1323 def test_vars(self
):
1324 self
.assertEqual(set(vars()), set(dir()))
1326 self
.assertEqual(set(vars(sys
)), set(dir(sys
)))
1327 self
.assertEqual(self
.get_vars_f0(), {})
1328 self
.assertEqual(self
.get_vars_f2(), {'a': 1, 'b': 2})
1329 self
.assertRaises(TypeError, vars, 42, 42)
1330 self
.assertRaises(TypeError, vars, 42)
1335 t
= [(1, 4), (2, 5), (3, 6)]
1336 self
.assertEqual(zip(a
, b
), t
)
1338 self
.assertEqual(zip(a
, b
), t
)
1340 self
.assertEqual(zip(a
, b
), t
)
1342 def __getitem__(self
, i
):
1343 if i
< 0 or i
> 2: raise IndexError
1345 self
.assertEqual(zip(a
, I()), t
)
1346 self
.assertEqual(zip(), [])
1347 self
.assertEqual(zip(*[]), [])
1348 self
.assertRaises(TypeError, zip, None)
1351 self
.assertRaises(TypeError, zip, a
, G())
1353 # Make sure zip doesn't try to allocate a billion elements for the
1354 # result list when one of its arguments doesn't say how long it is.
1355 # A MemoryError is the most likely failure mode.
1356 class SequenceWithoutALength
:
1357 def __getitem__(self
, i
):
1363 zip(SequenceWithoutALength(), xrange(2**30)),
1364 list(enumerate(range(5)))
1368 def __getitem__(self
, i
):
1373 self
.assertRaises(ValueError, zip, BadSeq(), BadSeq())
1375 def test_format(self
):
1376 # Test the basic machinery of the format() builtin. Don't test
1377 # the specifics of the various formatters
1378 self
.assertEqual(format(3, ''), '3')
1380 # Returns some classes to use for various tests. There's
1381 # an old-style version, and a new-style version
1384 def __init__(self
, x
):
1386 def __format__(self
, format_spec
):
1387 return str(self
.x
) + format_spec
1388 class DerivedFromA(A
):
1391 class Simple(object): pass
1392 class DerivedFromSimple(Simple
):
1393 def __init__(self
, x
):
1395 def __format__(self
, format_spec
):
1396 return str(self
.x
) + format_spec
1397 class DerivedFromSimple2(DerivedFromSimple
): pass
1398 return A
, DerivedFromA
, DerivedFromSimple
, DerivedFromSimple2
1400 # In 3.0, classes_classic has the same meaning as classes_new
1401 def classes_classic():
1403 def __init__(self
, x
):
1405 def __format__(self
, format_spec
):
1406 return str(self
.x
) + format_spec
1407 class DerivedFromA(A
):
1411 class DerivedFromSimple(Simple
):
1412 def __init__(self
, x
):
1414 def __format__(self
, format_spec
):
1415 return str(self
.x
) + format_spec
1416 class DerivedFromSimple2(DerivedFromSimple
): pass
1417 return A
, DerivedFromA
, DerivedFromSimple
, DerivedFromSimple2
1419 def class_test(A
, DerivedFromA
, DerivedFromSimple
, DerivedFromSimple2
):
1420 self
.assertEqual(format(A(3), 'spec'), '3spec')
1421 self
.assertEqual(format(DerivedFromA(4), 'spec'), '4spec')
1422 self
.assertEqual(format(DerivedFromSimple(5), 'abc'), '5abc')
1423 self
.assertEqual(format(DerivedFromSimple2(10), 'abcdef'),
1426 class_test(*classes_new())
1427 class_test(*classes_classic())
1429 def empty_format_spec(value
):
1431 # format(x, '') == str(x)
1432 # format(x) == str(x)
1433 self
.assertEqual(format(value
, ""), str(value
))
1434 self
.assertEqual(format(value
), str(value
))
1436 # for builtin types, format(x, "") == str(x)
1437 empty_format_spec(17**13)
1438 empty_format_spec(1.0)
1439 empty_format_spec(3.1415e104
)
1440 empty_format_spec(-3.1415e104
)
1441 empty_format_spec(3.1415e-104)
1442 empty_format_spec(-3.1415e-104)
1443 empty_format_spec(object)
1444 empty_format_spec(None)
1446 # TypeError because self.__format__ returns the wrong type
1447 class BadFormatResult
:
1448 def __format__(self
, format_spec
):
1450 self
.assertRaises(TypeError, format
, BadFormatResult(), "")
1452 # TypeError because format_spec is not unicode or str
1453 self
.assertRaises(TypeError, format
, object(), 4)
1454 self
.assertRaises(TypeError, format
, object(), object())
1456 # tests for object.__format__ really belong elsewhere, but
1457 # there's no good place to put them
1458 x
= object().__format
__('')
1459 self
.assertTrue(x
.startswith('<object object at'))
1461 # first argument to object.__format__ must be string
1462 self
.assertRaises(TypeError, object().__format
__, 3)
1463 self
.assertRaises(TypeError, object().__format
__, object())
1464 self
.assertRaises(TypeError, object().__format
__, None)
1466 # make sure we can take a subclass of str as a format spec
1467 class DerivedFromStr(str): pass
1468 self
.assertEqual(format(0, DerivedFromStr('10')), ' 0')
1471 self
.assertEqual(bin(0), '0b0')
1472 self
.assertEqual(bin(1), '0b1')
1473 self
.assertEqual(bin(-1), '-0b1')
1474 self
.assertEqual(bin(2**65), '0b1' + '0' * 65)
1475 self
.assertEqual(bin(2**65-1), '0b' + '1' * 65)
1476 self
.assertEqual(bin(-(2**65)), '-0b1' + '0' * 65)
1477 self
.assertEqual(bin(-(2**65-1)), '-0b' + '1' * 65)
1479 def test_bytearray_translate(self
):
1480 x
= bytearray("abc")
1481 self
.assertRaises(ValueError, x
.translate
, "1", 1)
1482 self
.assertRaises(TypeError, x
.translate
, "1"*256, 1)
1484 class TestSorted(unittest
.TestCase
):
1486 def test_basic(self
):
1489 random
.shuffle(copy
)
1490 self
.assertEqual(data
, sorted(copy
))
1491 self
.assertNotEqual(data
, copy
)
1494 random
.shuffle(copy
)
1495 self
.assertEqual(data
, sorted(copy
, cmp=lambda x
, y
: cmp(y
,x
)))
1496 self
.assertNotEqual(data
, copy
)
1497 random
.shuffle(copy
)
1498 self
.assertEqual(data
, sorted(copy
, key
=lambda x
: -x
))
1499 self
.assertNotEqual(data
, copy
)
1500 random
.shuffle(copy
)
1501 self
.assertEqual(data
, sorted(copy
, reverse
=1))
1502 self
.assertNotEqual(data
, copy
)
1504 def test_inputtypes(self
):
1506 types
= [list, tuple]
1508 types
.insert(0, unicode)
1510 self
.assertEqual(sorted(s
), sorted(T(s
)))
1512 s
= ''.join(dict.fromkeys(s
).keys()) # unique letters only
1513 types
= [set, frozenset, list, tuple, dict.fromkeys
]
1515 types
.insert(0, unicode)
1517 self
.assertEqual(sorted(s
), sorted(T(s
)))
1519 def test_baddecorator(self
):
1520 data
= 'The quick Brown fox Jumped over The lazy Dog'.split()
1521 self
.assertRaises(TypeError, sorted, data
, None, lambda x
,y
: 0)
1523 def test_main(verbose
=None):
1524 test_classes
= (BuiltinTest
, TestSorted
)
1526 run_unittest(*test_classes
)
1528 # verify reference counting
1529 if verbose
and hasattr(sys
, "gettotalrefcount"):
1532 for i
in xrange(len(counts
)):
1533 run_unittest(*test_classes
)
1535 counts
[i
] = sys
.gettotalrefcount()
1539 if __name__
== "__main__":
1540 test_main(verbose
=True)