[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
bug#67839: [PATCH v2 2/2] service: Add asserts that used to make tests/r
From: |
Attila Lendvai |
Subject: |
bug#67839: [PATCH v2 2/2] service: Add asserts that used to make tests/replacement.sh fail. |
Date: |
Sun, 17 Dec 2023 01:44:25 +0100 |
* modules/shepherd/service.scm (spawn-service-controller): Add two asserts.
This is the bug that causes `guix system reconfigure ...` to sometimes hang,
and subsequently all shepherd commands, because a match-error flies out from
the service-controller of a replaced service, and thus its fiber dies. These
asserts get triggered without the previous commit that fixes the issue.
---
modules/shepherd/service.scm | 2 ++
1 file changed, 2 insertions(+)
diff --git a/modules/shepherd/service.scm b/modules/shepherd/service.scm
index c3bdf44..0ee6929 100644
--- a/modules/shepherd/service.scm
+++ b/modules/shepherd/service.scm
@@ -382,9 +382,11 @@ denoting what the service provides."
(define (spawn-service-controller service)
"Return a channel over which @var{service} may be controlled."
+ (assert (current-process-monitor))
(let ((channel (make-channel)))
(spawn-fiber
(lambda ()
+ (assert (current-process-monitor))
;; The controller writes to its current output port via 'local-output'.
;; Make sure that goes to the right port. If the controller got a
;; wrong output port, it could crash and stop responding just because a
--
2.41.0