diff options
| author | Andrew MacIntyre <andymac@bullseye.apana.org.au> | 2004-04-04 07:01:35 +0000 | 
|---|---|---|
| committer | Andrew MacIntyre <andymac@bullseye.apana.org.au> | 2004-04-04 07:01:35 +0000 | 
| commit | 4e10ed3b86cf08211ef0c9c5408799195c2c1881 (patch) | |
| tree | aa4ba6c69b025b087a79eea302c9ed6d0ccb6ca8 /Lib/test/test_file.py | |
| parent | ba813e20892157befdefa60df88c19bae52fc766 (diff) | |
| download | cpython-git-4e10ed3b86cf08211ef0c9c5408799195c2c1881.tar.gz | |
If a file is opened with an explicit buffer size >= 1, repeated
close() calls would attempt to free() the buffer already free()ed on
the first close().     [bug introduced with patch #788249]
Making sure that the buffer is free()ed in file object deallocation is
a belt-n-braces bit of insurance against a memory leak.
Diffstat (limited to 'Lib/test/test_file.py')
| -rw-r--r-- | Lib/test/test_file.py | 17 | 
1 files changed, 17 insertions, 0 deletions
| diff --git a/Lib/test/test_file.py b/Lib/test/test_file.py index b8bcab7bd8..22db9a2920 100644 --- a/Lib/test/test_file.py +++ b/Lib/test/test_file.py @@ -109,6 +109,23 @@ f.close()  if not f.closed:      raise TestFailed, 'file.closed should be true' +# make sure that explicitly setting the buffer size doesn't cause +# misbehaviour especially with repeated close() calls +for s in (-1, 0, 1, 512): +    try: +        f = open(TESTFN, 'w', s) +        f.write(str(s)) +        f.close() +        f.close() +        f = open(TESTFN, 'r', s) +        d = int(f.read()) +        f.close() +        f.close() +    except IOError, msg: +        raise TestFailed, 'error setting buffer size %d: %s' % (s, str(msg)) +    if d != s: +        raise TestFailed, 'readback failure using buffer size %d' +  methods = ['fileno', 'flush', 'isatty', 'next', 'read', 'readinto',             'readline', 'readlines', 'seek', 'tell', 'truncate', 'write',             'xreadlines', '__iter__'] | 
