pgsql: Test that vacuum removes tuples older than OldestXmin

Поиск
Список
Период
Сортировка
От Melanie Plageman
Тема pgsql: Test that vacuum removes tuples older than OldestXmin
Дата
Msg-id E1sUqGT-000HlA-6C@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Test that vacuum removes tuples older than OldestXmin

If vacuum fails to prune a tuple killed before OldestXmin, it will
decide to freeze its xmax and later error out in pre-freeze checks.

Add a test reproducing this scenario to the recovery suite which creates
a table on a primary, updates the table to generate dead tuples for
vacuum, and then, during the vacuum, uses a replica to force
GlobalVisState->maybe_needed on the primary to move backwards and
precede the value of OldestXmin set at the beginning of vacuuming the
table.

This commit is separate from the fix in case there are test stability
issues.

Author: Melanie Plageman
Reviewed-by: Peter Geoghegan
Discussion: https://postgr.es/m/CAAKRu_apNU2MPBK96V%2BbXjTq0RiZ-%3DA4ZTaysakpx9jxbq1dbQ%40mail.gmail.com

Branch
------
REL_17_STABLE

Details
-------
https://git.postgresql.org/pg/commitdiff/80c34692e8e674e3b2f150f248ef2002ae2ac3a7

Modified Files
--------------
src/test/recovery/meson.build                   |   1 +
src/test/recovery/t/043_vacuum_horizon_floor.pl | 268 ++++++++++++++++++++++++
2 files changed, 269 insertions(+)


В списке pgsql-committers по дате отправления:

Предыдущее
От: Heikki Linnakangas
Дата:
Сообщение: pgsql: Move resowner from common JitContext to LLVM specific
Следующее
От: Nathan Bossart
Дата:
Сообщение: pgsql: Add overflow checks to money type.