Page MenuHomeFreeBSD

daemon: truncate the pidfile when we're waiting to restart child
ClosedPublic

Authored by kevans on Oct 8 2024, 5:23 AM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Dec 15, 5:46 PM
Unknown Object (File)
Dec 9 2024, 5:55 AM
Unknown Object (File)
Nov 21 2024, 7:34 AM
Unknown Object (File)
Nov 20 2024, 9:01 AM
Unknown Object (File)
Nov 20 2024, 3:43 AM
Unknown Object (File)
Nov 19 2024, 8:47 PM
Unknown Object (File)
Nov 18 2024, 2:31 PM
Unknown Object (File)
Nov 14 2024, 8:15 PM
Subscribers

Details

Summary

We need to be able to test some more restart behavior that depends on
knowing specifically where we're at (inside the event loop or outside of the
event loop). Truncate the pidfile until the process is restarted to give
the test a clean marker rather than having to add arbitrary delays and
hoping for the best.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

kevans requested review of this revision.Oct 8 2024, 5:23 AM

rather than having to add arbitrary delays and hoping for the best.

From my reading, the test is still kinda doing that - daemon will sleep for 1s in between restarts by default, so that gives you a short window to check for a truncated pidfile. Were you going to take advantage of this change in other tests?

I think this change is probably ok, but I don't quite understand the justification.

usr.sbin/daemon/daemon.c
538

Is there a specific reason we don't just unlink the child pidfile?

854

This could reasonably live in libutil, but it's simple enough that this is fine for now.

rather than having to add arbitrary delays and hoping for the best.

From my reading, the test is still kinda doing that - daemon will sleep for 1s in between restarts by default, so that gives you a short window to check for a truncated pidfile. Were you going to take advantage of this change in other tests?

I think this change is probably ok, but I don't quite understand the justification.

It's a bit more clear after reading D47005.

This revision is now accepted and ready to land.Oct 8 2024, 12:12 PM
usr.sbin/daemon/daemon.c
538

The pidfile API takes a lock on the pidfile while we have it open- I wanted to avoid opening the opportunity for another daemon(8) to pop in and take the path since this is pretty much just an aide for testing.