tests: dhcpd: Avoid race conditions.

Those tests were racy: it could take a while for those files to appear
and for the shepherd service to be up.  Thus, wait a little longer for
each of them.

* gnu/tests/networking.scm (run-dhcpd-test)["pid file exists"]
["lease file exists"]: Use 'wait-for-file'.
["dhcpd is alive"]: Use 'wait-for-service'.
This commit is contained in:
Ludovic Courtès 2023-05-14 22:35:30 +02:00
parent da6e6d38f3
commit 8aaa5cf405
No known key found for this signature in database
GPG key ID: 090B11993D9AEBB5

View file

@ -412,8 +412,6 @@ (define test
(with-imported-modules '((gnu build marionette)) (with-imported-modules '((gnu build marionette))
#~(begin #~(begin
(use-modules (gnu build marionette) (use-modules (gnu build marionette)
(ice-9 popen)
(ice-9 rdelim)
(srfi srfi-64)) (srfi srfi-64))
(define marionette (define marionette
@ -423,16 +421,15 @@ (define marionette
(test-begin "dhcpd") (test-begin "dhcpd")
(test-assert "pid file exists" (test-assert "pid file exists"
(marionette-eval (wait-for-file
'(file-exists? '#$(dhcpd-configuration-pid-file dhcpd-v4-configuration)
#$(dhcpd-configuration-pid-file dhcpd-v4-configuration))
marionette)) marionette))
(test-assert "lease file exists" (test-assert "lease file exists"
(marionette-eval (wait-for-file
'(file-exists? '#$(dhcpd-configuration-lease-file dhcpd-v4-configuration)
#$(dhcpd-configuration-lease-file dhcpd-v4-configuration)) marionette
marionette)) #:read '(@ (ice-9 textual-ports) get-string-all)))
(test-assert "run directory exists" (test-assert "run directory exists"
(marionette-eval (marionette-eval
@ -443,13 +440,8 @@ (define marionette
(test-assert "dhcpd is alive" (test-assert "dhcpd is alive"
(marionette-eval (marionette-eval
'(begin '(begin
(use-modules (gnu services herd) (use-modules (gnu services herd))
(srfi srfi-1)) (wait-for-service 'dhcpv4-daemon))
(live-service-running
(find (lambda (live)
(memq 'dhcpv4-daemon
(live-service-provision live)))
(current-services))))
marionette)) marionette))
(test-end)))) (test-end))))