mirror of
				https://github.com/psycopg/psycopg2.git
				synced 2025-10-25 04:51:08 +03:00 
			
		
		
		
	Merge branch 'nul-terminator' into maint_2_6
This commit is contained in:
		
						commit
						9a6b7e8b10
					
				
							
								
								
									
										2
									
								
								NEWS
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								NEWS
									
									
									
									
									
								
							|  | @ -4,6 +4,8 @@ Current release | ||||||
| What's new in psycopg 2.6.3 | What's new in psycopg 2.6.3 | ||||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||||||
| 
 | 
 | ||||||
|  | - Throw an exception trying to pass ``NULL`` chars as parameters | ||||||
|  |   (:ticket:`#420). | ||||||
| - Make `~psycopg2.extras.Range` objects picklable (:ticket:`#462`). | - Make `~psycopg2.extras.Range` objects picklable (:ticket:`#462`). | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -50,8 +50,13 @@ psycopg_escape_string(connectionObject *conn, const char *from, Py_ssize_t len, | ||||||
|     Py_ssize_t ql; |     Py_ssize_t ql; | ||||||
|     int eq = (conn && (conn->equote)) ? 1 : 0; |     int eq = (conn && (conn->equote)) ? 1 : 0; | ||||||
| 
 | 
 | ||||||
|     if (len == 0) |     if (len == 0) { | ||||||
|         len = strlen(from); |         len = strlen(from); | ||||||
|  |     } else if (strchr(from, '\0') != from + len) { | ||||||
|  |         PyErr_Format(PyExc_ValueError, "A string literal cannot contain NUL (0x00) characters."); | ||||||
|  | 
 | ||||||
|  | 	return NULL; | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|     if (to == NULL) { |     if (to == NULL) { | ||||||
|         to = (char *)PyMem_Malloc((len * 2 + 4) * sizeof(char)); |         to = (char *)PyMem_Malloc((len * 2 + 4) * sizeof(char)); | ||||||
|  |  | ||||||
|  | @ -62,6 +62,15 @@ class QuotingTestCase(ConnectingTestCase): | ||||||
|         self.assertEqual(res, data) |         self.assertEqual(res, data) | ||||||
|         self.assert_(not self.conn.notices) |         self.assert_(not self.conn.notices) | ||||||
| 
 | 
 | ||||||
|  |     def test_string_null_terminator(self): | ||||||
|  |         curs = self.conn.cursor() | ||||||
|  |         data = 'abcd\x01\x00cdefg' | ||||||
|  | 
 | ||||||
|  |         with self.assertRaises(ValueError) as e: | ||||||
|  |             curs.execute("SELECT %s", (data,)) | ||||||
|  | 
 | ||||||
|  |         self.assertEquals(e.exception.message, 'A string literal cannot contain NUL (0x00) characters.') | ||||||
|  | 
 | ||||||
|     def test_binary(self): |     def test_binary(self): | ||||||
|         data = b("""some data with \000\013 binary |         data = b("""some data with \000\013 binary | ||||||
|         stuff into, 'quotes' and \\ a backslash too. |         stuff into, 'quotes' and \\ a backslash too. | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user