diff options
author | Barry Warsaw <barry@python.org> | 1996-12-18 19:56:22 (GMT) |
---|---|---|
committer | Barry Warsaw <barry@python.org> | 1996-12-18 19:56:22 (GMT) |
commit | a09ec19a332de34de493b2c4da2b89b46fadc370 (patch) | |
tree | 8ff87f4304c6d847e26397403eaa30f8bd0b4f6d /Lib | |
parent | 39900421bfad095ea5d029dca201d262a94c8f66 (diff) | |
download | cpython-a09ec19a332de34de493b2c4da2b89b46fadc370.zip cpython-a09ec19a332de34de493b2c4da2b89b46fadc370.tar.gz cpython-a09ec19a332de34de493b2c4da2b89b46fadc370.tar.bz2 |
Test of the operator module
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/test/output/test_operator | 1 | ||||
-rw-r--r-- | Lib/test/test_operator.py | 76 | ||||
-rw-r--r-- | Lib/test/testall.py | 1 |
3 files changed, 78 insertions, 0 deletions
diff --git a/Lib/test/output/test_operator b/Lib/test/output/test_operator new file mode 100644 index 0000000..d2d7da2 --- /dev/null +++ b/Lib/test/output/test_operator @@ -0,0 +1 @@ +test_operator diff --git a/Lib/test/test_operator.py b/Lib/test/test_operator.py new file mode 100644 index 0000000..b2dad62 --- /dev/null +++ b/Lib/test/test_operator.py @@ -0,0 +1,76 @@ +import operator +import sys + +def test(name, input, output, *args): + f = getattr(operator, name) + params = (input,) + args + try: + val = apply(f, params) + except: + val = sys.exc_type + if val <> output: + print '%s%s = %s: %s expected' % (f.__name__, params, `val`, `output`) + +test('abs', -1, 1) +test('add', 3, 7, 4) +test('and_', 0xf, 0xa, 0xa) +test('concat', 'py', 'python', 'thon') + +test('countOf', [1, 2, 1, 3, 1, 4], 1, 3) + +a = [4, 3, 2, 1] +test('delitem', a, None, 1) +if a <> [4, 2, 1]: + print 'delitem() failed' + +a = range(10) +test('delslice', a, None, 2, 8) +if a <> [0, 1, 8, 9]: + print 'delslice() failed' + +a = range(10) +test('div', 5, 2, 2) +test('getitem', a, 2, 2) +test('getslice', a, [4, 5], 4, 6) +test('indexOf', [4, 3, 2, 1], 1, 3) +test('inv', 4, -5) +test('isCallable', 4, 0) +test('isCallable', operator.isCallable, 1) +test('isMappingType', operator.isMappingType, 0) +test('isMappingType', operator.__dict__, 1) +test('isNumberType', 8.3, 1) +test('isNumberType', dir(), 0) +test('isSequenceType', dir(), 1) +test('isSequenceType', 'yeahbuddy', 1) +test('isSequenceType', 3, 0) +test('lshift', 5, 10, 1) +test('mod', 5, 1, 2) +test('mul', 5, 10, 2) +test('neg', 5, -5) +test('or_', 0xa, 0xf, 0x5) +test('pos', -5, -5) + +a = range(3) +test('repeat', a, a+a, 2) +test('rshift', 5, 2, 1) + +test('sequenceIncludes', range(4), 1, 2) +test('sequenceIncludes', range(4), 0, 5) + +test('setitem', a, None, 0, 2) +if a <> [2, 1, 2]: + print 'setitem() failed' + +a = range(4) +test('setslice', a, None, 1, 3, [2, 1]) +if a <> [0, 2, 1, 3]: + print 'setslice() failed:', a + +test('sub', 5, 2, 3) +test('truth', 5, 1) +test('truth', [], 0) +test('xor', 0xb, 0x7, 0xc) + + +# some negative tests +test('indexOf', [4, 3, 2, 1], ValueError, 9) diff --git a/Lib/test/testall.py b/Lib/test/testall.py index 318ab4c..3dc30c3 100644 --- a/Lib/test/testall.py +++ b/Lib/test/testall.py @@ -29,6 +29,7 @@ tests = ['test_grammar', 'test_fcntl', 'test_gdbm', 'test_grp', + 'test_operator', ] if __name__ == '__main__': |