BUG/MEDIUM: peers: Don't use resync timer when local resync is in progress

When a worker is stopped, the resync timer is used to limit in time the
connection stage to the new worker to perform the local resync. However,
this timer must be stopped when the resync is in progress and it must be
re-armed if the resync is interrupted (for instance because another
reload). Otherwise, if the resync is a bit long, an old worker may be killed
too early.

This bug was introduce by the commit 160fff665 ("BUG/MEDIUM: peers: limit
reconnect attempts of the old process on reload"). It must be backported as
far as 2.0.

(cherry picked from commit 19a82b94953ae06839b34df2fc1e57847bef7c50)
Signed-off-by: Christopher Faulet <cfaulet@haproxy.com>
(cherry picked from commit 36581bfa58735e6f5fd50cd35da99aa75d56e559)
Signed-off-by: Christopher Faulet <cfaulet@haproxy.com>
(cherry picked from commit bf11a44f94f919797ea8570924c17333136b2a87)
Signed-off-by: Christopher Faulet <cfaulet@haproxy.com>
diff --git a/src/peers.c b/src/peers.c
index 1866baa..49d8558 100644
--- a/src/peers.c
+++ b/src/peers.c
@@ -3153,6 +3153,10 @@
 			}
 		}
 		else if (!ps->appctx) {
+			/* Re-arm resync timeout if necessary */
+			if (!tick_isset(peers->resync_timeout))
+				peers->resync_timeout = tick_add(now_ms, MS_TO_TICKS(PEER_RESYNC_TIMEOUT));
+
 			/* If there's no active peer connection */
 			if (!tick_is_expired(peers->resync_timeout, now_ms) &&
 			    (ps->statuscode == 0 ||
@@ -3188,6 +3192,9 @@
 			}
 		}
 		else if (ps->statuscode == PEER_SESS_SC_SUCCESSCODE ) {
+			/* Reset resync timeout during a resync */
+			peers->resync_timeout = TICK_ETERNITY;
+
 			/* current peer connection is active and established
 			 * wake up all peer handlers to push remaining local updates */
 			for (st = ps->tables; st ; st = st->next) {