summaryrefslogtreecommitdiffstats
path: root/http-backend.c
diff options
context:
space:
mode:
authorMax Kirillov <max@max630.net>2018-11-24 14:48:27 +0100
committerJunio C Hamano <gitster@pobox.com>2018-11-26 03:10:18 +0100
commit02818a98d7bddbc036fe6a1ceea847c6de20ed00 (patch)
tree9483ada714869d05bb563f282c61d2032535a4a6 /http-backend.c
parentGit 2.19.2 (diff)
downloadgit-02818a98d7bddbc036fe6a1ceea847c6de20ed00.tar.xz
git-02818a98d7bddbc036fe6a1ceea847c6de20ed00.zip
http-backend: enable cleaning up forked upload/receive-pack on exit
If http-backend dies because of errors, started upload-pack or receive-pack are not killed and waited, but rather stay running for some time until they exit because of closed stdin. It may be undesirable in working environment, and it also causes occasional failure of t5562, because the processes keep opened act.err, and sometimes write there errors after next test started using the file. Fix by enabling cleaning of the command at http-backed exit. Reported-by: Carlo Arenas <carenas@gmail.com> Helped-by: Carlo Arenas <carenas@gmail.com> Signed-off-by: Max Kirillov <max@max630.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'http-backend.c')
-rw-r--r--http-backend.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/http-backend.c b/http-backend.c
index 458642ef72..ebf268cace 100644
--- a/http-backend.c
+++ b/http-backend.c
@@ -486,6 +486,8 @@ static void run_service(const char **argv, int buffer_input)
if (buffer_input || gzipped_request || req_len >= 0)
cld.in = -1;
cld.git_cmd = 1;
+ cld.clean_on_exit = 1;
+ cld.wait_after_clean = 1;
if (start_command(&cld))
exit(1);