Commit
abb0b4fc03 moved the shared state for autoprewarm to a
dynamic shared memory (DSM) segment, but it left apw_detach_shmem()
in the on_shmem_exit callback list for the autoprewarm leader
process. This is a problem because shmem_exit() detaches all the
DSM segments prior to calling the on_shmem_exit callbacks, thus
producing segfaults in the exit path for the autoprewarm leader
process.
To fix, move apw_detach_shmem() to the before_shmem_exit callback
list. This commit also adds a check to pg_prewarm's test that the
server shut down normally. It might be worth making this a common
check for all shutdowns in TAP tests, but that is left as a future
exercise.
Reported-by: Andres Freund
Reviewed-by: Andres Freund, Álvaro Herrera
Discussion: https://postgr.es/m/
20240122204117.swton324xcoodnyi%40awork3.anarazel.de
if (apw_init_shmem())
first_time = false;
- /* Set on-detach hook so that our PID will be cleared on exit. */
- on_shmem_exit(apw_detach_shmem, 0);
+ /*
+ * Set on-detach hook so that our PID will be cleared on exit.
+ *
+ * NB: Autoprewarm's state is stored in a DSM segment, and DSM segments
+ * are detached before calling the on_shmem_exit callbacks, so we must put
+ * apw_detach_shmem in the before_shmem_exit callback list.
+ */
+ before_shmem_exit(apw_detach_shmem, 0);
/*
* Store our PID in the shared memory area --- unless there's already
$node->stop;
+# control file should indicate normal shut down
+command_like(
+ [ 'pg_controldata', $node->data_dir() ],
+ qr/Database cluster state:\s*shut down/,
+ 'cluster shut down normally');
+
done_testing();