GNU bug report logs - #77220
[shepherd]: Timers do not set HOME environment variable correctly

Previous Next

Package: guix;

Reported by: Tomas Volf <~@wolfsden.cz>

Date: Sun, 23 Mar 2025 21:31:01 UTC

Severity: normal

Done: Tomas Volf <~@wolfsden.cz>

Bug is archived. No further changes may be made.

Full log


View this message in rfc822 format

From: Tomas Volf <~@wolfsden.cz>
To: Ludovic Courtès <ludo <at> gnu.org>
Cc: 77220 <at> debbugs.gnu.org
Subject: bug#77220: [shepherd]: Timers do not set HOME environment variable correctly
Date: Wed, 16 Apr 2025 00:38:18 +0200
[Message part 1 (text/plain, inline)]
Ludovic Courtès <ludo <at> gnu.org> writes:

> [..]
>
>> +@deffn {Procedure} user-environment-variables @
>> +  [name-or-id (getuid)] @
>> +  [environment-variables (default-environment-variables)]
>> +
>> +Take the list of environment variables, replace @env{HOME} with home
>
> “Take the list @var{environment-variables}, …”

Done.

>
>> +(define-module (test-service)
>> +  #:use-module (shepherd service)
>> +  #:use-module (srfi srfi-64))
>> +
>> +
>> +(test-begin "user-environment-variables")
>
> (test-begin "service"), to create ‘service.log’.

Well, I did the change, but I would just like to note that the
`service.log' file was created (with expected content) even in the
previous version.

The runner in test-driver.scm used by Shepherd does not set the
group-begin handler, so the value passed to test-begin is effectively
ignored.  At least it does not seem to be used for anything.

>
>> +(let ((environment-variables '("USER=foo"
>> +                               "HOME=/foo"
>> +                               "USER=bar"
>> +                               "HOME=/bar")))
>> +  ;; Pretty much any system should have root in /etc/passwd.
>> +  (test-equal "name sets variables"
>> +    '("HOME=/root" "USER=root")
>> +    (user-environment-variables "root" environment-variables))
>
> Use (passwd:name (getpwuid (getuid))) rather than “root” because
> /etc/passwd in the Guix build environment does not have “root”.  (You
> can test with ‘guix build -f guix.scm’.)

I did not realize that, fixed.

>
> OK with these changes, thank you!

v2 attached. :)

Tomas

[v2-0001-service-Add-user-environment-variables-procedure.patch (text/x-patch, inline)]
From 9e93429cdb0aa6c0e133642c9cd53bdd8e3d9613 Mon Sep 17 00:00:00 2001
From: Tomas Volf <~@wolfsden.cz>
Date: Wed, 16 Apr 2025 00:16:14 +0200
Subject: [PATCH v2] service: Add user-environment-variables procedure.

* modules/shepherd/service.scm (user-environment-variables): New procedure.
* doc/shepherd.texi (Service De- and Constructors): Document it.
* tests/service.scm: And test it.
---
 Makefile.am                  |  1 +
 doc/shepherd.texi            |  9 ++++++++
 modules/shepherd/service.scm | 16 +++++++++++++-
 tests/service.scm            | 43 ++++++++++++++++++++++++++++++++++++
 4 files changed, 68 insertions(+), 1 deletion(-)
 create mode 100644 tests/service.scm

diff --git a/Makefile.am b/Makefile.am
index 7404009..a61b403 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -296,6 +296,7 @@ TESTS =						\
   tests/syslog-slow-output.sh			\
   tests/terminate-before-running.sh		\
   tests/unload.sh				\
+  tests/service.scm				\
   tests/services/monitoring.sh			\
   tests/services/repl.sh			\
   tests/services/timer.sh			\
diff --git a/doc/shepherd.texi b/doc/shepherd.texi
index f826b74..2da92e3 100644
--- a/doc/shepherd.texi
+++ b/doc/shepherd.texi
@@ -1203,6 +1203,15 @@ returns when the program starts (@pxref{Runtime Environment,
 @code{environ},, guile, GNU Guile Reference Manual}).
 @end defvar
 
+@deffn {Procedure} user-environment-variables @
+  [name-or-id (getuid)] @
+  [environment-variables (default-environment-variables)]
+
+Take the list @var{environment-variables}, replace @env{HOME} with home
+directory of the user and @env{USER} with the name of the user and
+return the result.
+@end deffn
+
 @defvar default-pid-file-timeout
 This parameter (@pxref{Parameters,,, guile, GNU Guile Reference Manual})
 specifies the default PID file timeout in seconds, when
diff --git a/modules/shepherd/service.scm b/modules/shepherd/service.scm
index 2e39b72..5b66ab8 100644
--- a/modules/shepherd/service.scm
+++ b/modules/shepherd/service.scm
@@ -127,6 +127,7 @@
             default-respawn-delay
             default-service-termination-handler
             default-environment-variables
+            user-environment-variables
             default-service-directory
             make-forkexec-constructor
             make-kill-destructor
@@ -1486,6 +1487,20 @@ background:~{ ~a~}."
   ;; set when starting a service.
   (make-parameter '()))
 
+(define* (user-environment-variables #:optional
+                                     (name-or-id (getuid))
+                                     (environment-variables
+                                      (default-environment-variables)))
+  "Return the value of @var{environment-variables} with @env{HOME} and
+@env{USER} replaced by correct values for user @var{name-or-id}."
+  (let ((pw (getpw name-or-id)))
+    (cons* (string-append "HOME=" (passwd:dir pw))
+           (string-append "USER=" (passwd:name pw))
+           (remove (lambda (x)
+                     (or (string-prefix? "HOME=" x)
+                         (string-prefix? "USER=" x)))
+                   environment-variables))))
+
 (define default-pid-file-timeout
   ;; Maximum number of seconds to wait for a PID file to show up.
   (make-parameter 5))
@@ -2992,4 +3007,3 @@ we want to receive these signals."
       "This does not work for the 'root' service."
       (lambda (running)
 	(local-output (l10n "You must be kidding.")))))))
-
diff --git a/tests/service.scm b/tests/service.scm
new file mode 100644
index 0000000..a802a39
--- /dev/null
+++ b/tests/service.scm
@@ -0,0 +1,43 @@
+;; GNU Shepherd --- Test the service module.
+;; Copyright © 2025 Tomas Volf <~@wolfsden.cz>
+;;
+;; This file is part of the GNU Shepherd.
+;;
+;; The GNU Shepherd is free software; you can redistribute it and/or modify it
+;; under the terms of the GNU General Public License as published by
+;; the Free Software Foundation; either version 3 of the License, or (at
+;; your option) any later version.
+;;
+;; The GNU Shepherd is distributed in the hope that it will be useful, but
+;; WITHOUT ANY WARRANTY; without even the implied warranty of
+;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+;; GNU General Public License for more details.
+;;
+;; You should have received a copy of the GNU General Public License
+;; along with the GNU Shepherd.  If not, see <http://www.gnu.org/licenses/>.
+
+(define-module (test-service)
+  #:use-module (shepherd service)
+  #:use-module (srfi srfi-64))
+
+
+(test-begin "service")
+
+(let* ((environment-variables '("USER=foo"
+                                "HOME=/foo"
+                                "USER=bar"
+                                "HOME=/bar"))
+
+       (passwd (getpwuid (getuid)))
+       (user (passwd:name passwd))
+
+       (expected (list (string-append "HOME=" (passwd:dir passwd))
+                       (string-append "USER=" user))))
+  (test-equal "name sets variables"
+    expected
+    (user-environment-variables user environment-variables))
+  (test-equal "id sets variables"
+    expected
+    (user-environment-variables (getuid) environment-variables)))
+
+(test-end)
-- 
2.49.0

[Message part 3 (text/plain, inline)]

-- 
There are only two hard things in Computer Science:
cache invalidation, naming things and off-by-one errors.

This bug report was last modified 92 days ago.

Previous Next


GNU bug tracking system
Copyright (C) 1999 Darren O. Benham, 1997,2003 nCipher Corporation Ltd, 1994-97 Ian Jackson.