For some reason I've ended up using -Dsegsize_blocks=4 and I've started getting ninja test errors after getting back from vacation leave like below (so this test was included only since then):
stderr: # Failed test 'worker: normal: test reading of invalid block 2,3 in larger read: expected stderr' # at /git/postgres/src/test/modules/test_aio/t/001_aio.pl line 989. # 'psql:<stdin>:55: ERROR: read crossing segment boundary' # doesn't match '(?^:^psql:<stdin>:\d+: ERROR: 2 invalid pages among blocks 1..4 of relation "base/.*/.*\nDETAIL: Block 2 held the first invalid page\.\nHINT:[^\n]+$)' # Failed test 'worker: normal: test zeroing of invalid block 2,3 in larger read, ZERO_ON_ERROR: expected stderr' # at /git/postgres/src/test/modules/test_aio/t/001_aio.pl line 999. # 'psql:<stdin>:59: ERROR: read crossing segment boundary' # doesn't match '(?^:^psql:<stdin>:\d+: WARNING: zeroing out 2 invalid pages among blocks 1..4 of relation "base/.*/.*\nDETAIL: Block 2 held the first zeroed page\.\nHINT:[^\n]+$)' # Failed test 'worker: normal: test zeroing of invalid block 2,3 in larger read, zero_damaged_pages: expected stderr' # at /git/postgres/src/test/modules/test_aio/t/001_aio.pl line 1009. # 'psql:<stdin>:66: ERROR: read crossing segment boundary' [..] # at /git/postgres/src/test/modules/test_aio/t/001_aio.pl line 1353. # 'psql:<stdin>:62: ERROR: read crossing segment boundary' # doesn't match '(?^:^psql:<stdin>:\d+: ERROR: invalid page in block 4 of relation "base/\d+/\d+"$)' # Failed test 'worker: test reading of valid block 1, checksum failed 2, 3, invalid 3-5, zero=true: expected stderr' # at /git/postgres/src/test/modules/test_aio/t/001_aio.pl line 1375. # 'psql:<stdin>:77: ERROR: read crossing segment boundary' [..] with segsize_blocks=5 I've got: # Failed test 'worker: temp rel: test reading of invalid block 4, valid block 5: expected stderr' # at /git/postgres/src/test/modules/test_aio/t/001_aio.pl line 1158. # 'psql:<stdin>:66: ERROR: read crossing segment boundary' # doesn't match '(?^:^psql:<stdin>:\d+: ERROR: invalid page in block 4 of relation "base/\d+/t\d+_\d+"$)' # Failed test 'worker: test reading of valid block 1, checksum failed 2, 3, invalid 3-5, zero=true: expected stderr' # at /git/postgres/src/test/modules/test_aio/t/001_aio.pl line 1375. # 'psql:<stdin>:77: ERROR: read crossing segment boundary' # doesn't match '(?^:^psql:<stdin>:\d+: WARNING: zeroing 3 page\(s\) and ignoring 2 checksum failure\(s\) among blocks 1..5 of relation ")' # die: death by signal at /git/postgres/src/test/perl/PostgreSQL/Test/Cluster.pm line 181. .cirrus file show usage of segsize_blocks=6, and also 8 works fine without errors, so it's just nuisance on my side, but it took some minutes for me to realize this and I'll just ask maybe we should just block usage of RELSEG_SIZE < 6 blocks in meson/configure? (patch attached) -J.
From 7156e31d14f1b2b37ee3b82a5ca4a8c69bbcf3a3 Mon Sep 17 00:00:00 2001 From: Jakub Wartak <[email protected]> Date: Wed, 8 Apr 2026 08:47:25 +0200 Subject: [PATCH v1] Limit minimum allowed segsize-blocks in autoconf/meson to avoid blowing up tests --- configure | 4 ++++ configure.ac | 4 ++++ meson.build | 3 +++ 3 files changed, 11 insertions(+) diff --git a/configure b/configure index f66c1054a7a..af49854e7df 100755 --- a/configure +++ b/configure @@ -3796,6 +3796,10 @@ if test $segsize_blocks -ne 0 -a $segsize -ne 1; then $as_echo "$as_me: WARNING: both --with-segsize and --with-segsize-blocks specified, --with-segsize-blocks wins" >&2;} fi +if test $segsize_blocks -ne 0 -a $segsize_blocks -lt 6; then + as_fn_error $? "too small segsize-blocks specified" "$LINENO" 5 +fi + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for segment size" >&5 $as_echo_n "checking for segment size... " >&6; } if test $segsize_blocks -eq 0; then diff --git a/configure.ac b/configure.ac index 8d176bd3468..c01bfceb7a0 100644 --- a/configure.ac +++ b/configure.ac @@ -290,6 +290,10 @@ if test $segsize_blocks -ne 0 -a $segsize -ne 1; then AC_MSG_WARN([both --with-segsize and --with-segsize-blocks specified, --with-segsize-blocks wins]) fi +if test $segsize_blocks -ne 0 -a $segsize_blocks -lt 6; then + AC_MSG_ERROR([too small segsize-blocks specified]) +fi + AC_MSG_CHECKING([for segment size]) if test $segsize_blocks -eq 0; then # this expression is set up to avoid unnecessary integer overflow diff --git a/meson.build b/meson.build index be97e986e5d..d77343f5a64 100644 --- a/meson.build +++ b/meson.build @@ -512,6 +512,9 @@ if get_option('segsize_blocks') != 0 if get_option('segsize') != 1 warning('both segsize and segsize_blocks specified, segsize_blocks wins') endif + if get_option('segsize_blocks') < 6 + error('too small segsize_blocks specified') + endif segsize = get_option('segsize_blocks') else -- 2.43.0
