diff --git a/src/ostree/ot-builtin-trivial-httpd.c b/src/ostree/ot-builtin-trivial-httpd.c index 31c541a4..f4e303c6 100644 --- a/src/ostree/ot-builtin-trivial-httpd.c +++ b/src/ostree/ot-builtin-trivial-httpd.c @@ -28,6 +28,8 @@ #include "otutil.h" #include +#include +#include static char *opt_port_file = NULL; static gboolean opt_daemonize; @@ -390,7 +392,7 @@ ostree_builtin_trivial_httpd (int argc, char **argv, GCancellable *cancellable, #if !SOUP_CHECK_VERSION(2, 48, 0) soup_server_run_async (server); #endif - + if (opt_daemonize) { pid_t pid = fork(); @@ -411,6 +413,21 @@ ostree_builtin_trivial_httpd (int argc, char **argv, GCancellable *cancellable, fclose (stdout); fclose (stdin); } + else + { + /* Since we're used for testing purposes, let's just do this by + * default. This ensures we exit when our parent does. + */ + if (prctl (PR_SET_PDEATHSIG, SIGTERM) != 0) + { + int errsv = errno; + if (errsv != ENOSYS) + { + ot_util_set_error_from_errno (error, errsv); + goto out; + } + } + } app->running = TRUE; if (opt_autoexit)