mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-22 14:32:25 +03:00 
			
		
		
		
	The txid_XXX family of fmgr functions exposes 64 bit transaction IDs to users as int8. Now that we have an SQL type xid8 for FullTransactionId, define a new set of functions including pg_current_xact_id() and pg_current_snapshot() based on that. Keep the old functions around too, for now. It's a bit sneaky to use the same C functions for both, but since the binary representation is identical except for the signedness of the type, and since older functions are the ones using the wrong signedness, and since we'll presumably drop the older ones after a reasonable period of time, it seems reasonable to switch to FullTransactionId internally and share the code for both. Reviewed-by: Fujii Masao <masao.fujii@oss.nttdata.com> Reviewed-by: Takao Fujii <btfujiitkp@oss.nttdata.com> Reviewed-by: Yoshikazu Imai <imai.yoshikazu@fujitsu.com> Reviewed-by: Mark Dilger <mark.dilger@enterprisedb.com> Discussion: https://postgr.es/m/20190725000636.666m5mad25wfbrri%40alap3.anarazel.de
		
			
				
	
	
		
			44 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			RPMSpec
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			RPMSpec
		
	
	
	
	
	
| # Test snapshot transfer from subxact to top-level and receival of later snaps.
 | |
| 
 | |
| setup
 | |
| {
 | |
|     SELECT 'init' FROM pg_create_logical_replication_slot('isolation_slot', 'test_decoding'); -- must be first write in xact
 | |
|     DROP TABLE IF EXISTS dummy;
 | |
|     CREATE TABLE dummy(i int);
 | |
|     DROP TABLE IF EXISTS harvest;
 | |
|     CREATE TABLE harvest(apples int, pears int);
 | |
| }
 | |
| 
 | |
| teardown
 | |
| {
 | |
|     DROP TABLE IF EXISTS harvest;
 | |
|     DROP TABLE IF EXISTS dummy;
 | |
|     SELECT 'stop' FROM pg_drop_replication_slot('isolation_slot');
 | |
| }
 | |
| 
 | |
| session "s0"
 | |
| setup { SET synchronous_commit=on; }
 | |
| step "s0_begin" { BEGIN; }
 | |
| step "s0_begin_sub0" { SAVEPOINT s0; }
 | |
| step "s0_log_assignment" { SELECT pg_current_xact_id() IS NULL; }
 | |
| step "s0_begin_sub1" { SAVEPOINT s1; }
 | |
| step "s0_sub_get_base_snap" { INSERT INTO dummy VALUES (0); }
 | |
| step "s0_insert" { INSERT INTO harvest VALUES (1, 2, 3); }
 | |
| step "s0_end_sub0" { RELEASE SAVEPOINT s0; }
 | |
| step "s0_end_sub1" { RELEASE SAVEPOINT s1; }
 | |
| step "s0_commit" { COMMIT; }
 | |
| step "s0_get_changes" { SELECT data FROM pg_logical_slot_get_changes('isolation_slot', NULL, NULL, 'include-xids', '0', 'skip-empty-xacts', '1'); }
 | |
| 
 | |
| session "s1"
 | |
| setup { SET synchronous_commit=on; }
 | |
| step "s1_produce_new_snap" { ALTER TABLE harvest ADD COLUMN mangos int; }
 | |
| 
 | |
| # start top-level without base snap, get base snap in subxact, then create new
 | |
| # snap and make sure it is queued.
 | |
| permutation "s0_begin" "s0_begin_sub0" "s0_log_assignment" "s0_sub_get_base_snap" "s1_produce_new_snap" "s0_insert" "s0_end_sub0" "s0_commit" "s0_get_changes"
 | |
| 
 | |
| # In previous test, we firstly associated subxact with xact and only then got
 | |
| # base snap; now nest one more subxact to get snap first and only then (at
 | |
| # commit) associate it with toplevel.
 | |
| permutation "s0_begin" "s0_begin_sub0" "s0_log_assignment" "s0_begin_sub1" "s0_sub_get_base_snap" "s1_produce_new_snap" "s0_insert" "s0_end_sub1" "s0_end_sub0" "s0_commit" "s0_get_changes"
 |