mirror of
				https://github.com/python/cpython.git
				synced 2025-10-26 11:14:33 +00:00 
			
		
		
		
	Issue #19092 - Raise a correct exception when cgi.FieldStorage is given an
invalid file-obj. Also use __bool__ to determine the bool of the FieldStorage object.
This commit is contained in:
		
							parent
							
								
									5636eb7b93
								
							
						
					
					
						commit
						b4cbb92fbe
					
				
					 3 changed files with 22 additions and 2 deletions
				
			
		
							
								
								
									
										14
									
								
								Lib/cgi.py
									
										
									
									
									
								
							
							
						
						
									
										14
									
								
								Lib/cgi.py
									
										
									
									
									
								
							|  | @ -32,10 +32,12 @@ | |||
| # ======= | ||||
| 
 | ||||
| from io import StringIO, BytesIO, TextIOWrapper | ||||
| from collections import Mapping | ||||
| import sys | ||||
| import os | ||||
| import urllib.parse | ||||
| from email.parser import FeedParser | ||||
| from email.message import Message | ||||
| from warnings import warn | ||||
| import html | ||||
| import locale | ||||
|  | @ -472,18 +474,24 @@ def __init__(self, fp=None, headers=None, outerboundary=b'', | |||
|                 self.qs_on_post = environ['QUERY_STRING'] | ||||
|             if 'CONTENT_LENGTH' in environ: | ||||
|                 headers['content-length'] = environ['CONTENT_LENGTH'] | ||||
|         else: | ||||
|             if not (isinstance(headers, (Mapping, Message))): | ||||
|                 raise TypeError("headers must be mapping or an instance of " | ||||
|                                 "email.message.Message") | ||||
|         self.headers = headers | ||||
|         if fp is None: | ||||
|             self.fp = sys.stdin.buffer | ||||
|         # self.fp.read() must return bytes | ||||
|         elif isinstance(fp, TextIOWrapper): | ||||
|             self.fp = fp.buffer | ||||
|         else: | ||||
|             if not (hasattr(fp, 'read') and hasattr(fp, 'readline')): | ||||
|                 raise TypeError("fp must be file pointer") | ||||
|             self.fp = fp | ||||
| 
 | ||||
|         self.encoding = encoding | ||||
|         self.errors = errors | ||||
| 
 | ||||
|         self.headers = headers | ||||
|         if not isinstance(outerboundary, bytes): | ||||
|             raise TypeError('outerboundary must be bytes, not %s' | ||||
|                             % type(outerboundary).__name__) | ||||
|  | @ -636,7 +644,9 @@ def __len__(self): | |||
|         """Dictionary style len(x) support.""" | ||||
|         return len(self.keys()) | ||||
| 
 | ||||
|     def __nonzero__(self): | ||||
|     def __bool__(self): | ||||
|         if self.list is None: | ||||
|             raise TypeError("Cannot be converted to bool.") | ||||
|         return bool(self.list) | ||||
| 
 | ||||
|     def read_urlencoded(self): | ||||
|  |  | |||
|  | @ -137,6 +137,13 @@ def test_fieldstorage_properties(self): | |||
|         fs.list.append(namedtuple('MockFieldStorage', 'name')('fieldvalue')) | ||||
|         self.assertTrue(fs) | ||||
| 
 | ||||
|     def test_fieldstorage_invalid(self): | ||||
|         self.assertRaises(TypeError, cgi.FieldStorage, "not-a-file-obj", | ||||
|                                                             environ={"REQUEST_METHOD":"PUT"}) | ||||
|         self.assertRaises(TypeError, cgi.FieldStorage, "foo", "bar") | ||||
|         fs = cgi.FieldStorage(headers={'content-type':'text/plain'}) | ||||
|         self.assertRaises(TypeError, bool, fs) | ||||
| 
 | ||||
|     def test_escape(self): | ||||
|         # cgi.escape() is deprecated. | ||||
|         with warnings.catch_warnings(): | ||||
|  |  | |||
|  | @ -43,6 +43,9 @@ Core and Builtins | |||
| Library | ||||
| ------- | ||||
| 
 | ||||
| - Issue #19097: Raise the correct Exception when cgi.FieldStorage is given an | ||||
|   Invalid fileobj. | ||||
| 
 | ||||
| - Issue #20217: Fix build in SCHED_SPORADIC is defined. | ||||
| 
 | ||||
| - Issue #13107: argparse and optparse no longer raises an exception when output | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Senthil Kumaran
						Senthil Kumaran