index a8b12d9af6e3ea14045b78915c7a575bb9eff2e5..bad02edf90abfc3def7665616820df9f3e3e94bc 100644 (file)
@@ -140,6 +140,13 @@ is($result, qq{1}, "check table contents after point-in-time recovery");
# back to this timeline.
$node_pitr->safe_psql('postgres', "INSERT INTO foo VALUES(3);");
+# Wait for the archiver to be running. The startup process might have yet to
+# exit, in which case the postmaster has not started the archiver. If we
+# stop() without an archiver, the archive will be incomplete.
+$node_pitr->poll_query_until('postgres',
+ "SELECT true FROM pg_stat_activity WHERE backend_type = 'archiver';")
+ or die "Timed out while waiting for archiver to start";
+
# Stop the node. This archives the last segment.
$node_pitr->stop();