From b8c5d3ce9dc2571ac062a5974e276890dad04000 Mon Sep 17 00:00:00 2001 From: Karl Nilsson Date: Thu, 8 Aug 2024 09:47:21 +0100 Subject: [PATCH] Kill snapshot process before deleting everything If there is a snapshot process pending it could cause the directory deletion to fail, best kill the snapshot process first. --- src/ra_log.erl | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/src/ra_log.erl b/src/ra_log.erl index 57b17dca..033b35e5 100644 --- a/src/ra_log.erl +++ b/src/ra_log.erl @@ -933,8 +933,23 @@ read_config(Dir) -> ra_lib:consult(ConfigPath). -spec delete_everything(state()) -> ok. -delete_everything(#?MODULE{cfg = #cfg{directory = Dir}} = Log) -> +delete_everything(#?MODULE{cfg = #cfg{directory = Dir}, + snapshot_state = SnapState} = Log) -> _ = close(Log), + %% if there is a snapshot process pending it could cause the directory + %% deletion to fail, best kill the snapshot process first + case ra_snapshot:pending(SnapState) of + {Pid, _, _} -> + case is_process_alive(Pid) of + true -> + exit(Pid, kill), + ok; + false -> + ok + end; + _ -> + ok + end, try ra_lib:recursive_delete(Dir) of ok -> ok catch