mirror of
				https://github.com/psycopg/psycopg2.git
				synced 2025-10-26 05:21:03 +03:00 
			
		
		
		
	Added complete roundtrip test with copy_expert and Unicode
This commit is contained in:
		
							parent
							
								
									6098ced761
								
							
						
					
					
						commit
						75c61c2e80
					
				|  | @ -78,7 +78,7 @@ class CopyTests(unittest.TestCase): | ||||||
|         curs = self.conn.cursor() |         curs = self.conn.cursor() | ||||||
|         curs.execute(''' |         curs.execute(''' | ||||||
|             CREATE TEMPORARY TABLE tcopy ( |             CREATE TEMPORARY TABLE tcopy ( | ||||||
|               id int PRIMARY KEY, |               id serial PRIMARY KEY, | ||||||
|               data text |               data text | ||||||
|             )''') |             )''') | ||||||
| 
 | 
 | ||||||
|  | @ -180,6 +180,39 @@ class CopyTests(unittest.TestCase): | ||||||
|         f.seek(0) |         f.seek(0) | ||||||
|         self.assertEqual(f.readline().rstrip(), about) |         self.assertEqual(f.readline().rstrip(), about) | ||||||
| 
 | 
 | ||||||
|  |     @skip_if_no_iobase | ||||||
|  |     def test_copy_expert_textiobase(self): | ||||||
|  |         self.conn.set_client_encoding('latin1') | ||||||
|  |         self._create_temp_table()  # the above call closed the xn | ||||||
|  | 
 | ||||||
|  |         if sys.version_info[0] < 3: | ||||||
|  |             abin = ''.join(map(chr, range(32, 127) + range(160, 256))) | ||||||
|  |             abin = abin.decode('latin1') | ||||||
|  |             about = abin.replace('\\', '\\\\') | ||||||
|  | 
 | ||||||
|  |         else: | ||||||
|  |             abin = bytes(range(32, 127) + range(160, 256)).decode('latin1') | ||||||
|  |             about = abin.replace('\\', '\\\\') | ||||||
|  | 
 | ||||||
|  |         import io | ||||||
|  |         f = io.StringIO() | ||||||
|  |         f.write(about) | ||||||
|  |         f.seek(0) | ||||||
|  | 
 | ||||||
|  |         curs = self.conn.cursor() | ||||||
|  |         psycopg2.extensions.register_type( | ||||||
|  |             psycopg2.extensions.UNICODE, curs) | ||||||
|  | 
 | ||||||
|  |         curs.copy_expert('COPY tcopy (data) FROM STDIN', f) | ||||||
|  |         curs.execute("select data from tcopy;") | ||||||
|  |         self.assertEqual(curs.fetchone()[0], abin) | ||||||
|  | 
 | ||||||
|  |         f = io.StringIO() | ||||||
|  |         curs.copy_expert('COPY tcopy (data) TO STDOUT', f) | ||||||
|  |         f.seek(0) | ||||||
|  |         self.assertEqual(f.readline().rstrip(), about) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|     def _copy_from(self, curs, nrecs, srec, copykw): |     def _copy_from(self, curs, nrecs, srec, copykw): | ||||||
|         f = StringIO() |         f = StringIO() | ||||||
|         for i, c in izip(xrange(nrecs), cycle(string.ascii_letters)): |         for i, c in izip(xrange(nrecs), cycle(string.ascii_letters)): | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user