mirror of
https://github.com/postgres/postgres.git
synced 2025-07-02 09:02:37 +03:00
Fix cache-dependent test failures in logical decoding.
The regression test added in commit1230be12f
failed with CLOBBER_CACHE_ALWAYS builds as it depends on cache behavior. This test failure occurred only on v13 because the original data loss problem was fixed differently in v13 compared to v14 and later versions, resulting in different expected-output files. This commit adds an extra expected-output file to cover both regular and CLOBBER_CACHE_ALWAYS build cases. Oversight in1230be12f
. Per buildfarm member trilobite. Reported-by: Alexander Lakhin <exclusion@gmail.com> Reviewed-by: Amit Kapila <amit.kapila16@gmail.com> Reviewed-by: Hayato Kuroda <kuroda.hayato@fujitsu.com> Reviewed-by: Michael Paquier <michael@paquier.xyz> Discussion: https://postgr.es/m/dbf561f7-465e-4086-adfa-733b9b9a34b3@gmail.com
This commit is contained in:
@ -1,6 +1,10 @@
|
||||
# Test that catalog cache invalidation messages are distributed to ongoing
|
||||
# transactions, ensuring they can access the updated catalog content after
|
||||
# processing these messages.
|
||||
#
|
||||
# This file contains a cache-behavior-dependent test case. Its result is
|
||||
# different between regular and CLOBBER_CACHE_ALWAYS builds, so we must have
|
||||
# two expected-output files to cover both cases.
|
||||
setup
|
||||
{
|
||||
SELECT 'init' FROM pg_create_logical_replication_slot('isolation_slot', 'pgoutput');
|
||||
@ -40,4 +44,10 @@ permutation "s1_insert_tbl1" "s1_begin" "s1_insert_tbl1" "s2_alter_pub_add_tbl"
|
||||
# Expect to get no change because both s1's and s3's transactions
|
||||
# use the snapshot from before adding the table tbl1 to the
|
||||
# publication by "s2_alter_pub_add_tbl".
|
||||
#
|
||||
# Note that with CLOBBER_CACHE_ALWAYS, we expect to get one insert
|
||||
# change with LOGICAL_REP_MSG_INSERT = 'I' from the second
|
||||
# "s1_insert_tbl1" executed after adding the table tbl1 to the
|
||||
# publication in "s2_alter_pub_add_tbl" as the cache for table tbl1
|
||||
# is forcibly flushed due to CLOBBER_CACHE_ALWAYS.
|
||||
permutation "s1_begin" "s1_insert_tbl1" "s3_begin" "s3_insert_tbl1" "s2_alter_pub_add_tbl" "s1_insert_tbl1" "s1_commit" "s3_commit" "s2_get_binary_changes"
|
||||
|
Reference in New Issue
Block a user