mirror of
				https://github.com/python/cpython.git
				synced 2025-10-24 18:33:49 +00:00 
			
		
		
		
	Issue #20335: bytes constructor now raises TypeError when encoding or errors
is specified with non-string argument. Based on patch by Renaud Blanch.
This commit is contained in:
		
							parent
							
								
									9d98c9bf42
								
							
						
					
					
						commit
						83cf99d733
					
				
					 3 changed files with 18 additions and 7 deletions
				
			
		|  | @ -100,6 +100,14 @@ class C: | |||
|         self.assertRaises(TypeError, self.type2test, [0.0]) | ||||
|         self.assertRaises(TypeError, self.type2test, [None]) | ||||
|         self.assertRaises(TypeError, self.type2test, [C()]) | ||||
|         self.assertRaises(TypeError, self.type2test, 0, 'ascii') | ||||
|         self.assertRaises(TypeError, self.type2test, b'', 'ascii') | ||||
|         self.assertRaises(TypeError, self.type2test, 0, errors='ignore') | ||||
|         self.assertRaises(TypeError, self.type2test, b'', errors='ignore') | ||||
|         self.assertRaises(TypeError, self.type2test, '') | ||||
|         self.assertRaises(TypeError, self.type2test, '', errors='ignore') | ||||
|         self.assertRaises(TypeError, self.type2test, '', b'ascii') | ||||
|         self.assertRaises(TypeError, self.type2test, '', 'ascii', b'ignore') | ||||
| 
 | ||||
|     def test_constructor_value_errors(self): | ||||
|         self.assertRaises(ValueError, self.type2test, [-1]) | ||||
|  |  | |||
|  | @ -11,6 +11,9 @@ Release date: TBA | |||
| Core and Builtins | ||||
| ----------------- | ||||
| 
 | ||||
| - Issue #20335: bytes constructor now raises TypeError when encoding or errors | ||||
|   is specified with non-string argument.  Based on patch by Renaud Blanch. | ||||
| 
 | ||||
| - Issue #22335: Fix crash when trying to enlarge a bytearray to 0x7fffffff | ||||
|   bytes on a 32-bit platform. | ||||
| 
 | ||||
|  |  | |||
|  | @ -2503,6 +2503,13 @@ bytes_new(PyTypeObject *type, PyObject *args, PyObject *kwds) | |||
|         return new; | ||||
|     } | ||||
| 
 | ||||
|     /* If it's not unicode, there can't be encoding or errors */ | ||||
|     if (encoding != NULL || errors != NULL) { | ||||
|         PyErr_SetString(PyExc_TypeError, | ||||
|             "encoding or errors without a string argument"); | ||||
|         return NULL; | ||||
|     } | ||||
| 
 | ||||
|     /* We'd like to call PyObject_Bytes here, but we need to check for an
 | ||||
|        integer argument before deferring to PyBytes_FromObject, something | ||||
|        PyObject_Bytes doesn't do. */ | ||||
|  | @ -2544,13 +2551,6 @@ bytes_new(PyTypeObject *type, PyObject *args, PyObject *kwds) | |||
|         return new; | ||||
|     } | ||||
| 
 | ||||
|     /* If it's not unicode, there can't be encoding or errors */ | ||||
|     if (encoding != NULL || errors != NULL) { | ||||
|         PyErr_SetString(PyExc_TypeError, | ||||
|             "encoding or errors without a string argument"); | ||||
|         return NULL; | ||||
|     } | ||||
| 
 | ||||
|     return PyBytes_FromObject(x); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Serhiy Storchaka
						Serhiy Storchaka