diff options
author | Berker Peksag <berker.peksag@gmail.com> | 2015-02-06 08:21:37 (GMT) |
---|---|---|
committer | Berker Peksag <berker.peksag@gmail.com> | 2015-02-06 08:21:37 (GMT) |
commit | bf5e9604cc5a5ae61181b093193286f06a502ad6 (patch) | |
tree | c20966ea695e430b9dddae88196def7aca84f309 | |
parent | 088ca8b9470e51b932b73d6b39d970b0292f2ba3 (diff) | |
download | cpython-bf5e9604cc5a5ae61181b093193286f06a502ad6.zip cpython-bf5e9604cc5a5ae61181b093193286f06a502ad6.tar.gz cpython-bf5e9604cc5a5ae61181b093193286f06a502ad6.tar.bz2 |
Issue #20289: cgi.FieldStorage() now supports the context management protocol.
-rw-r--r-- | Doc/library/cgi.rst | 7 | ||||
-rw-r--r-- | Doc/whatsnew/3.5.rst | 6 | ||||
-rwxr-xr-x | Lib/cgi.py | 6 | ||||
-rw-r--r-- | Lib/test/test_cgi.py | 19 | ||||
-rw-r--r-- | Misc/NEWS | 3 |
5 files changed, 35 insertions, 6 deletions
diff --git a/Doc/library/cgi.rst b/Doc/library/cgi.rst index fa13145..0a9e884 100644 --- a/Doc/library/cgi.rst +++ b/Doc/library/cgi.rst @@ -157,6 +157,9 @@ return bytes):: if not line: break linecount = linecount + 1 +:class:`FieldStorage` objects also support being used in a :keyword:`with` +statement, which will automatically close them when done. + If an error is encountered when obtaining the contents of an uploaded file (for example, when the user interrupts the form submission by clicking on a Back or Cancel button) the :attr:`~FieldStorage.done` attribute of the @@ -182,6 +185,10 @@ A form submitted via POST that also has a query string will contain both The :attr:`~FieldStorage.file` attribute is automatically closed upon the garbage collection of the creating :class:`FieldStorage` instance. +.. versionchanged:: 3.5 + Added support for the context management protocol to the + :class:`FieldStorage` class. + Higher Level Interface ---------------------- diff --git a/Doc/whatsnew/3.5.rst b/Doc/whatsnew/3.5.rst index 979d241..461a14b 100644 --- a/Doc/whatsnew/3.5.rst +++ b/Doc/whatsnew/3.5.rst @@ -136,6 +136,12 @@ New Modules Improved Modules ================ +cgi +--- + +* :class:`FieldStorage` now supports the context management protocol. + (Contributed by Berker Peksag in :issue:`20289`.) + code ---- @@ -566,6 +566,12 @@ class FieldStorage: except AttributeError: pass + def __enter__(self): + return self + + def __exit__(self, *args): + self.file.close() + def __repr__(self): """Return a printable representation.""" return "FieldStorage(%r, %r, %r)" % ( diff --git a/Lib/test/test_cgi.py b/Lib/test/test_cgi.py index 86e1f3a..89a6e84 100644 --- a/Lib/test/test_cgi.py +++ b/Lib/test/test_cgi.py @@ -1,4 +1,4 @@ -from test.support import run_unittest, check_warnings +from test.support import check_warnings import cgi import os import sys @@ -307,6 +307,17 @@ Content-Type: text/plain got = getattr(files[x], k) self.assertEqual(got, exp) + def test_fieldstorage_as_context_manager(self): + fp = BytesIO(b'x' * 10) + env = {'REQUEST_METHOD': 'PUT'} + with cgi.FieldStorage(fp=fp, environ=env) as fs: + content = fs.file.read() + self.assertFalse(fs.file.closed) + self.assertTrue(fs.file.closed) + self.assertEqual(content, 'x' * 10) + with self.assertRaisesRegex(ValueError, 'I/O operation on closed file'): + fs.file.read() + _qs_result = { 'key1': 'value1', 'key2': ['value2x', 'value2y'], @@ -481,9 +492,5 @@ Content-Transfer-Encoding: binary --AaB03x-- """ - -def test_main(): - run_unittest(CgiTests) - if __name__ == '__main__': - test_main() + unittest.main() @@ -235,6 +235,9 @@ Core and Builtins Library ------- +- Issue #20289: cgi.FieldStorage() now supports the context management + protocol. + - Issue #13128: Print response headers for CONNECT requests when debuglevel > 0. Patch by Demian Brecht. |