]> git.ipfire.org Git - thirdparty/postgresql.git/commitdiff
amcheck: Fix snapshot usage in bt_index_parent_check
authorÁlvaro Herrera <alvherre@kurilemu.de>
Wed, 21 Jan 2026 17:55:43 +0000 (18:55 +0100)
committerÁlvaro Herrera <alvherre@kurilemu.de>
Wed, 21 Jan 2026 17:55:43 +0000 (18:55 +0100)
We were using SnapshotAny to do some index checks, but that's wrong and
causes spurious errors when used on indexes created by CREATE INDEX
CONCURRENTLY.  Fix it to use an MVCC snapshot, and add a test for it.

Backpatch of 6bd469d26aca to branches 14-16.  I previously misidentified
the bug's origin: it came in with commit 7f563c09f890 (pg11-era, not
5ae2087202af as claimed previously), so all live branches are affected.

Also take the opportunity to fix some comments that we failed to update
in the original commits and apply pgperltidy.  In branch 14, remove the
unnecessary test plan specification (which would have need to have been
changed anyway; c.f. commit 549ec201d613.)

Diagnosed-by: Donghang Lin <donghanglin@gmail.com>
Author: Mihail Nikalayeu <mihailnikalayeu@gmail.com>
Reviewed-by: Andrey Borodin <x4mmm@yandex-team.ru>
Backpatch-through: 17
Discussion: https://postgr.es/m/CANtu0ojmVd27fEhfpST7RG2KZvwkX=dMyKUqg0KM87FkOSdz8Q@mail.gmail.com

contrib/amcheck/t/002_cic.pl
contrib/amcheck/verify_nbtree.c

index f4a24936b2c01bb3add51aef791be98da17284db..983d0b3cbdd0bed2d6e652de0ef87bc0a0f797f4 100644 (file)
@@ -78,7 +78,8 @@ $in_progress_h->query_safe(q(BEGIN; SELECT pg_current_xact_id();));
 # delete one row from table, while background transaction is in progress
 $node->safe_psql('postgres', q(DELETE FROM quebec WHERE i = 1;));
 # create index concurrently, which will skip the deleted row
-$node->safe_psql('postgres', q(CREATE INDEX CONCURRENTLY oscar ON quebec(i);));
+$node->safe_psql('postgres',
+       q(CREATE INDEX CONCURRENTLY oscar ON quebec(i);));
 
 # check index using bt_index_parent_check
 my $result = $node->psql('postgres',
index 7898c05c045fd2d7272c5034ff64fe69b88db52a..3de1c06c7cf2cc031a08abc4b3c9ade0997d256f 100644 (file)
@@ -92,9 +92,11 @@ typedef struct BtreeCheckState
        BufferAccessStrategy checkstrategy;
 
        /*
-        * Info for uniqueness checking. Fill these fields once per index check.
+        * Info for uniqueness checking. Fill this field and the one below once
+        * per index check.
         */
        IndexInfo  *indexinfo;
+       /* Table scan snapshot for heapallindexed and checkunique */
        Snapshot        snapshot;
 
        /*