mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 00:03:23 -04:00 
			
		
		
		
	Fix the tests on slow machines (per buildfarm). Add test for dropping on error. And also try to consume real changes from temporary slots. From: Petr Jelinek <petr.jelinek@2ndquadrant.com>
		
			
				
	
	
		
			51 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			PL/PgSQL
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			PL/PgSQL
		
	
	
	
	
	
| SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot_p', 'test_decoding');
 | |
| SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot_t', 'test_decoding', true);
 | |
| 
 | |
| SELECT pg_drop_replication_slot('regression_slot_p');
 | |
| SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot_p', 'test_decoding', false);
 | |
| 
 | |
| SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot_t2', 'test_decoding', true);
 | |
| 
 | |
| -- here we want to start a new session and wait till old one is gone
 | |
| select pg_backend_pid() as oldpid \gset
 | |
| \c -
 | |
| do 'declare c int = 0;
 | |
| begin
 | |
|   while (select count(*) from pg_replication_slots where active_pid = '
 | |
|     :'oldpid'
 | |
|   ') > 0 loop c := c + 1; perform pg_sleep(0.01); end loop;
 | |
|   raise log ''slot test looped % times'', c;
 | |
| end';
 | |
| 
 | |
| -- should fail because the temporary slots were dropped automatically
 | |
| SELECT pg_drop_replication_slot('regression_slot_t');
 | |
| SELECT pg_drop_replication_slot('regression_slot_t2');
 | |
| 
 | |
| -- permanent slot has survived
 | |
| SELECT pg_drop_replication_slot('regression_slot_p');
 | |
| 
 | |
| -- test switching between slots in a session
 | |
| SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot1', 'test_decoding', true);
 | |
| 
 | |
| CREATE TABLE replication_example(id SERIAL PRIMARY KEY, somedata int, text varchar(120));
 | |
| BEGIN;
 | |
| INSERT INTO replication_example(somedata, text) VALUES (1, 1);
 | |
| INSERT INTO replication_example(somedata, text) VALUES (1, 2);
 | |
| COMMIT;
 | |
| 
 | |
| SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot2', 'test_decoding', true);
 | |
| 
 | |
| INSERT INTO replication_example(somedata, text) VALUES (1, 3);
 | |
| 
 | |
| SELECT data FROM pg_logical_slot_get_changes('regression_slot1', NULL, NULL, 'include-xids', '0', 'skip-empty-xacts', '1');
 | |
| SELECT data FROM pg_logical_slot_get_changes('regression_slot2', NULL, NULL, 'include-xids', '0', 'skip-empty-xacts', '1');
 | |
| 
 | |
| DROP TABLE replication_example;
 | |
| 
 | |
| -- error
 | |
| SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot1', 'test_decoding', true);
 | |
| 
 | |
| -- both should error as they should be dropped on error
 | |
| SELECT pg_drop_replication_slot('regression_slot1');
 | |
| SELECT pg_drop_replication_slot('regression_slot2');
 |