mirror of
				https://github.com/msgpack/msgpack-python.git
				synced 2025-10-24 22:33:19 +00:00 
			
		
		
		
	Always raise TypeError for wrong argument types
The code that checks whether hooks are callable() (and some other type checks) should always raise TypeError on failure. Before this change, both ValueError and TypeError were used in an inconsistent way (C extension and Python implementation were not the same).
This commit is contained in:
		
							parent
							
								
									d5436c2819
								
							
						
					
					
						commit
						77046b839d
					
				
					 3 changed files with 10 additions and 10 deletions
				
			
		|  | @ -52,7 +52,7 @@ cdef inline init_ctx(unpack_context *ctx, | ||||||
|     ctx.user.object_hook = ctx.user.list_hook = <PyObject*>NULL |     ctx.user.object_hook = ctx.user.list_hook = <PyObject*>NULL | ||||||
| 
 | 
 | ||||||
|     if object_hook is not None and object_pairs_hook is not None: |     if object_hook is not None and object_pairs_hook is not None: | ||||||
|         raise ValueError("object_pairs_hook and object_hook are mutually exclusive.") |         raise TypeError("object_pairs_hook and object_hook are mutually exclusive.") | ||||||
| 
 | 
 | ||||||
|     if object_hook is not None: |     if object_hook is not None: | ||||||
|         if not PyCallable_Check(object_hook): |         if not PyCallable_Check(object_hook): | ||||||
|  | @ -227,7 +227,7 @@ cdef class Unpacker(object): | ||||||
|         if file_like: |         if file_like: | ||||||
|             self.file_like_read = file_like.read |             self.file_like_read = file_like.read | ||||||
|             if not PyCallable_Check(self.file_like_read): |             if not PyCallable_Check(self.file_like_read): | ||||||
|                 raise ValueError("`file_like.read` must be a callable.") |                 raise TypeError("`file_like.read` must be a callable.") | ||||||
|         if not max_buffer_size: |         if not max_buffer_size: | ||||||
|             max_buffer_size = INT_MAX |             max_buffer_size = INT_MAX | ||||||
|         if read_size > max_buffer_size: |         if read_size > max_buffer_size: | ||||||
|  |  | ||||||
|  | @ -159,7 +159,7 @@ class Unpacker(object): | ||||||
|             self._fb_feeding = True |             self._fb_feeding = True | ||||||
|         else: |         else: | ||||||
|             if not callable(file_like.read): |             if not callable(file_like.read): | ||||||
|                 raise ValueError("`file_like.read` must be callable") |                 raise TypeError("`file_like.read` must be callable") | ||||||
|             self.file_like = file_like |             self.file_like = file_like | ||||||
|             self._fb_feeding = False |             self._fb_feeding = False | ||||||
|         self._fb_buffers = [] |         self._fb_buffers = [] | ||||||
|  | @ -179,16 +179,16 @@ class Unpacker(object): | ||||||
|         self._ext_hook = ext_hook |         self._ext_hook = ext_hook | ||||||
| 
 | 
 | ||||||
|         if list_hook is not None and not callable(list_hook): |         if list_hook is not None and not callable(list_hook): | ||||||
|             raise ValueError('`list_hook` is not callable') |             raise TypeError('`list_hook` is not callable') | ||||||
|         if object_hook is not None and not callable(object_hook): |         if object_hook is not None and not callable(object_hook): | ||||||
|             raise ValueError('`object_hook` is not callable') |             raise TypeError('`object_hook` is not callable') | ||||||
|         if object_pairs_hook is not None and not callable(object_pairs_hook): |         if object_pairs_hook is not None and not callable(object_pairs_hook): | ||||||
|             raise ValueError('`object_pairs_hook` is not callable') |             raise TypeError('`object_pairs_hook` is not callable') | ||||||
|         if object_hook is not None and object_pairs_hook is not None: |         if object_hook is not None and object_pairs_hook is not None: | ||||||
|             raise ValueError("object_pairs_hook and object_hook are mutually " |             raise TypeError("object_pairs_hook and object_hook are mutually " | ||||||
|                             "exclusive") |                             "exclusive") | ||||||
|         if not callable(ext_hook): |         if not callable(ext_hook): | ||||||
|             raise ValueError("`ext_hook` is not callable") |             raise TypeError("`ext_hook` is not callable") | ||||||
| 
 | 
 | ||||||
|     def feed(self, next_bytes): |     def feed(self, next_bytes): | ||||||
|         if isinstance(next_bytes, array.array): |         if isinstance(next_bytes, array.array): | ||||||
|  |  | ||||||
|  | @ -31,7 +31,7 @@ def test_decode_pairs_hook(): | ||||||
|     assert unpacked[1] == prod_sum |     assert unpacked[1] == prod_sum | ||||||
| 
 | 
 | ||||||
| def test_only_one_obj_hook(): | def test_only_one_obj_hook(): | ||||||
|     with raises(ValueError): |     with raises(TypeError): | ||||||
|         unpackb(b'', object_hook=lambda x: x, object_pairs_hook=lambda x: x) |         unpackb(b'', object_hook=lambda x: x, object_pairs_hook=lambda x: x) | ||||||
| 
 | 
 | ||||||
| def test_bad_hook(): | def test_bad_hook(): | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Wouter Bolsterlee
						Wouter Bolsterlee