33 lines
1.2 KiB
RPMSpec
33 lines
1.2 KiB
RPMSpec
|
# Test that catalog cache invalidation messages are distributed to ongoing
|
||
|
# transactions, ensuring they can access the updated catalog content after
|
||
|
# processing these messages.
|
||
|
setup
|
||
|
{
|
||
|
SELECT 'init' FROM pg_create_logical_replication_slot('isolation_slot', 'pgoutput');
|
||
|
CREATE TABLE tbl1(val1 integer, val2 integer);
|
||
|
CREATE PUBLICATION pub;
|
||
|
}
|
||
|
|
||
|
teardown
|
||
|
{
|
||
|
DROP TABLE tbl1;
|
||
|
DROP PUBLICATION pub;
|
||
|
SELECT 'stop' FROM pg_drop_replication_slot('isolation_slot');
|
||
|
}
|
||
|
|
||
|
session "s1"
|
||
|
setup { SET synchronous_commit=on; }
|
||
|
|
||
|
step "s1_begin" { BEGIN; }
|
||
|
step "s1_insert_tbl1" { INSERT INTO tbl1 (val1, val2) VALUES (1, 1); }
|
||
|
step "s1_commit" { COMMIT; }
|
||
|
|
||
|
session "s2"
|
||
|
setup { SET synchronous_commit=on; }
|
||
|
|
||
|
step "s2_alter_pub_add_tbl" { ALTER PUBLICATION pub ADD TABLE tbl1; }
|
||
|
step "s2_get_binary_changes" { SELECT count(data) FROM pg_logical_slot_get_binary_changes('isolation_slot', NULL, NULL, 'proto_version', '4', 'publication_names', 'pub') WHERE get_byte(data, 0) = 73; }
|
||
|
|
||
|
# Expect to get one insert change. LOGICAL_REP_MSG_INSERT = 'I'
|
||
|
permutation "s1_insert_tbl1" "s1_begin" "s1_insert_tbl1" "s2_alter_pub_add_tbl" "s1_commit" "s1_insert_tbl1" "s2_get_binary_changes"
|