summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNoah Misch2023-07-01 17:00:39 +0000
committerNoah Misch2023-07-01 17:00:39 +0000
commit01d56eecee4cfa0f796c4ee3e2e0ac615b9350bb (patch)
tree2823d9cdfe13ee23840e536c12f55b50cdf56032
parente251e780bfe62168d0edfec459ebdc66b991753f (diff)
Fix test of pg_stat_io for wal_level=minimal.
Back-patch to v16, which introduced the test.
-rw-r--r--contrib/amcheck/expected/check_heap.out7
-rw-r--r--contrib/amcheck/sql/check_heap.sql8
2 files changed, 12 insertions, 3 deletions
diff --git a/contrib/amcheck/expected/check_heap.out b/contrib/amcheck/expected/check_heap.out
index 8f1beb4681c..979e5e84e72 100644
--- a/contrib/amcheck/expected/check_heap.out
+++ b/contrib/amcheck/expected/check_heap.out
@@ -76,11 +76,15 @@ INSERT INTO heaptest (a, b)
--
-- Create an alternative tablespace and move the heaptest table to it, causing
-- it to be rewritten and all the blocks to reliably evicted from shared
--- buffers -- guaranteeing actual reads when we next select from it.
+-- buffers -- guaranteeing actual reads when we next select from it in the
+-- same transaction. The heaptest table is smaller than the default
+-- wal_skip_threshold, so a wal_level=minimal commit reads the table into
+-- shared_buffers. A transaction delays that and excludes any autovacuum.
SET allow_in_place_tablespaces = true;
CREATE TABLESPACE regress_test_stats_tblspc LOCATION '';
SELECT sum(reads) AS stats_bulkreads_before
FROM pg_stat_io WHERE context = 'bulkread' \gset
+BEGIN;
ALTER TABLE heaptest SET TABLESPACE regress_test_stats_tblspc;
-- Check that valid options are not rejected nor corruption reported
-- for a non-empty table
@@ -104,6 +108,7 @@ SELECT * FROM verify_heapam(relation := 'heaptest', startblock := 0, endblock :=
-------+--------+--------+-----
(0 rows)
+COMMIT;
-- verify_heapam should have read in the page written out by
-- ALTER TABLE ... SET TABLESPACE ...
-- causing an additional bulkread, which should be reflected in pg_stat_io.
diff --git a/contrib/amcheck/sql/check_heap.sql b/contrib/amcheck/sql/check_heap.sql
index cf5ce4d0c0a..1745bae634e 100644
--- a/contrib/amcheck/sql/check_heap.sql
+++ b/contrib/amcheck/sql/check_heap.sql
@@ -36,19 +36,23 @@ INSERT INTO heaptest (a, b)
--
-- Create an alternative tablespace and move the heaptest table to it, causing
-- it to be rewritten and all the blocks to reliably evicted from shared
--- buffers -- guaranteeing actual reads when we next select from it.
+-- buffers -- guaranteeing actual reads when we next select from it in the
+-- same transaction. The heaptest table is smaller than the default
+-- wal_skip_threshold, so a wal_level=minimal commit reads the table into
+-- shared_buffers. A transaction delays that and excludes any autovacuum.
SET allow_in_place_tablespaces = true;
CREATE TABLESPACE regress_test_stats_tblspc LOCATION '';
SELECT sum(reads) AS stats_bulkreads_before
FROM pg_stat_io WHERE context = 'bulkread' \gset
+BEGIN;
ALTER TABLE heaptest SET TABLESPACE regress_test_stats_tblspc;
-
-- Check that valid options are not rejected nor corruption reported
-- for a non-empty table
SELECT * FROM verify_heapam(relation := 'heaptest', skip := 'none');
SELECT * FROM verify_heapam(relation := 'heaptest', skip := 'all-frozen');
SELECT * FROM verify_heapam(relation := 'heaptest', skip := 'all-visible');
SELECT * FROM verify_heapam(relation := 'heaptest', startblock := 0, endblock := 0);
+COMMIT;
-- verify_heapam should have read in the page written out by
-- ALTER TABLE ... SET TABLESPACE ...