* bug#71193: Shepherd fails to start a system when given an incorrect form to the start field of any service
@ 2024-05-25 7:33 Picnoir
2024-06-26 13:47 ` Ludovic Courtès
0 siblings, 1 reply; 2+ messages in thread
From: Picnoir @ 2024-05-25 7:33 UTC (permalink / raw)
To: 71193; +Cc: Ludovic Courtès
Hey Guix,
I'm facing a pretty annoying Shepherd 0.10.4 bug.
If a service start script gets provided an incorrect form, such as an
empty quoted list, Shepherd hangs during its early startup and bricks
the overall Guix system.
I think the following snippet is a good minimal reproducer for this. Add
this service to a guix system configuration:
--8<---------------cut here---------------start------------->8---
(simple-service
'shepherd-bug-repro
shepherd-root-service-type
(list (shepherd-service
(documentation "shepherd hang minimal repro")
(provision '(shepherd-bug-repro))
(requirement '())
(start #~('())))))
u--8<---------------cut here---------------end--------------->8---
⚠ DO NOT BOOT ON A CRITICAL SYSTEM WITH THIS SERVICE, IT'LL BRICK IT ⚠
You can create a VM for this system and start it. The VM hangs after the
log line "creating /etc/machine-id...", before any shepherd service gets
started.
You get the same behaviour if you end up booting by misfortune a "real"
system having this service.
Instead of having the whole system to freeze, I'd expect shepherd to
fail the particular service having an incorrect start form.
I'm not sure what's happening here. I did not manage to diagnose this further,
the shepherd does not seem to be super chatty at this stage of the boot.
Tested on Shepherd 0.10.4 with the Guix revision
c5e63e19ac672f9e63fc8ee98fa9a16f978ce19c.
^ permalink raw reply [flat|nested] 2+ messages in thread
* bug#71193: Shepherd fails to start a system when given an incorrect form to the start field of any service
2024-05-25 7:33 bug#71193: Shepherd fails to start a system when given an incorrect form to the start field of any service Picnoir
@ 2024-06-26 13:47 ` Ludovic Courtès
0 siblings, 0 replies; 2+ messages in thread
From: Ludovic Courtès @ 2024-06-26 13:47 UTC (permalink / raw)
To: Picnoir; +Cc: 71193
Hi Picnoir,
"Picnoir" <picnoir@alternativebit.fr> skribis:
> I think the following snippet is a good minimal reproducer for this. Add
> this service to a guix system configuration:
>
> --8<---------------cut here---------------start------------->8---
> (simple-service
> 'shepherd-bug-repro
> shepherd-root-service-type
> (list (shepherd-service
> (documentation "shepherd hang minimal repro")
> (provision '(shepherd-bug-repro))
> (requirement '())
> (start #~('())))))
> u--8<---------------cut here---------------end--------------->8---
>
> ⚠ DO NOT BOOT ON A CRITICAL SYSTEM WITH THIS SERVICE, IT'LL BRICK IT ⚠
>
> You can create a VM for this system and start it. The VM hangs after the
> log line "creating /etc/machine-id...", before any shepherd service gets
> started.
[...]
> Tested on Shepherd 0.10.4 with the Guix revision
> c5e63e19ac672f9e63fc8ee98fa9a16f978ce19c.
This sounds very much like <https://issues.guix.gnu.org/71144>, which
was fixed in Guix commit cca25a67693bb68a1884a081b415a43fad1e8641,
shortly after the commit you mention.
I tested the reproducer you posted in a VM and it boots fine. The
problem simply leads to an error message in /var/log/messages:
--8<---------------cut here---------------start------------->8---
Jun 26 15:43:09 localhost vmunix: [ 3.574026] shepherd[1]: Exception caught while loading '/gnu/store/c44hd3gfksalrbsgc3a0ax4v9jmnkzb4-shepherd-shepherd-bug-repro.go': #<&compound-exception components: (#<&assertion-failure> #<&origin origin: #f> #<&message message: "Wrong type to apply: ~S"> #<&i
Jun 26 15:43:09 localhost vmunix: [ 3.574132] rritants irritants: (())> #<&exception-with-kind-and-args kind: wrong-type-arg args: (#f "Wrong type to apply: ~S" (()) (()))>)>
Jun 26 15:43:09 localhost vmunix: [ 3.583838] shepherd[1]: starting services...
Jun 26 15:43:09 localhost vmunix: [ 3.585444] shepherd[1]: Configuration successfully loaded from '/gnu/store/8cch4dv5ca1v0hsgyr6d8jay513x7d8g-shepherd.conf'.
--8<---------------cut here---------------end--------------->8---
… and of course the faulty service doesn’t show up at all in ‘herd
status’.
Could you confirm it’s fine for you?
Thanks,
Ludo’.
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2024-06-26 13:49 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-05-25 7:33 bug#71193: Shepherd fails to start a system when given an incorrect form to the start field of any service Picnoir
2024-06-26 13:47 ` Ludovic Courtès
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/guix.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).