mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-25 12:09:15 -05:00
services: Statically report duplicate dmd service identifiers.
Reported by 白い熊 @相撲道 <guix-devel_gnu.org@sumou.com> at <http://lists.gnu.org/archive/html/guix-devel/2015-03/msg00264.html>. * gnu/services/dmd.scm (assert-no-duplicates): New procedure. (dmd-configuration-file): Use it. * po/guix/POTFILES.in: Add gnu/services/dmd.scm. * tests/guix-system.sh (errorfile): Add test.
This commit is contained in:
parent
b0b727808b
commit
116244df95
3 changed files with 63 additions and 1 deletions
|
@ -17,6 +17,8 @@
|
||||||
;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
|
;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
(define-module (gnu services dmd)
|
(define-module (gnu services dmd)
|
||||||
|
#:use-module (guix ui)
|
||||||
|
#:use-module (guix sets)
|
||||||
#:use-module (guix gexp)
|
#:use-module (guix gexp)
|
||||||
#:use-module (guix store)
|
#:use-module (guix store)
|
||||||
#:use-module (guix monads)
|
#:use-module (guix monads)
|
||||||
|
@ -24,6 +26,8 @@ (define-module (gnu services dmd)
|
||||||
#:use-module (gnu services)
|
#:use-module (gnu services)
|
||||||
#:use-module (ice-9 match)
|
#:use-module (ice-9 match)
|
||||||
#:use-module (srfi srfi-1)
|
#:use-module (srfi srfi-1)
|
||||||
|
#:use-module (srfi srfi-34)
|
||||||
|
#:use-module (srfi srfi-35)
|
||||||
#:export (dmd-configuration-file))
|
#:export (dmd-configuration-file))
|
||||||
|
|
||||||
;;; Commentary:
|
;;; Commentary:
|
||||||
|
@ -32,6 +36,26 @@ (define-module (gnu services dmd)
|
||||||
;;;
|
;;;
|
||||||
;;; Code:
|
;;; Code:
|
||||||
|
|
||||||
|
(define (assert-no-duplicates services)
|
||||||
|
"Raise an error if SERVICES provide the same dmd service more than once.
|
||||||
|
|
||||||
|
This is a constraint that dmd's 'register-service' verifies but we'd better
|
||||||
|
verify it here statically than wait until PID 1 halts with an assertion
|
||||||
|
failure."
|
||||||
|
(fold (lambda (service set)
|
||||||
|
(define (assert-unique symbol)
|
||||||
|
(when (set-contains? set symbol)
|
||||||
|
(raise (condition
|
||||||
|
(&message
|
||||||
|
(message
|
||||||
|
(format #f (_ "service '~a' provided more than once")
|
||||||
|
symbol)))))))
|
||||||
|
|
||||||
|
(for-each assert-unique (service-provision service))
|
||||||
|
(fold set-insert set (service-provision service)))
|
||||||
|
(setq)
|
||||||
|
services))
|
||||||
|
|
||||||
(define (dmd-configuration-file services)
|
(define (dmd-configuration-file services)
|
||||||
"Return the dmd configuration file for SERVICES."
|
"Return the dmd configuration file for SERVICES."
|
||||||
(define modules
|
(define modules
|
||||||
|
@ -40,6 +64,8 @@ (define modules
|
||||||
(gnu build file-systems)
|
(gnu build file-systems)
|
||||||
(guix build utils)))
|
(guix build utils)))
|
||||||
|
|
||||||
|
(assert-no-duplicates services)
|
||||||
|
|
||||||
(mlet %store-monad ((modules (imported-modules modules))
|
(mlet %store-monad ((modules (imported-modules modules))
|
||||||
(compiled (compiled-modules modules)))
|
(compiled (compiled-modules modules)))
|
||||||
(define config
|
(define config
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
# This should be source files of the various tools, and not package modules.
|
# This should be source files of the various tools, and not package modules.
|
||||||
gnu/packages.scm
|
gnu/packages.scm
|
||||||
gnu/system.scm
|
gnu/system.scm
|
||||||
|
gnu/services/dmd.scm
|
||||||
guix/scripts/build.scm
|
guix/scripts/build.scm
|
||||||
guix/scripts/download.scm
|
guix/scripts/download.scm
|
||||||
guix/scripts/package.scm
|
guix/scripts/package.scm
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
# GNU Guix --- Functional package management for GNU
|
# GNU Guix --- Functional package management for GNU
|
||||||
# Copyright © 2014 Ludovic Courtès <ludo@gnu.org>
|
# Copyright © 2014, 2015 Ludovic Courtès <ludo@gnu.org>
|
||||||
#
|
#
|
||||||
# This file is part of GNU Guix.
|
# This file is part of GNU Guix.
|
||||||
#
|
#
|
||||||
|
@ -28,6 +28,8 @@ tmpfile="t-guix-system-$$"
|
||||||
errorfile="t-guix-system-error-$$"
|
errorfile="t-guix-system-error-$$"
|
||||||
trap 'rm -f "$tmpfile" "$errorfile"' EXIT
|
trap 'rm -f "$tmpfile" "$errorfile"' EXIT
|
||||||
|
|
||||||
|
# Reporting of syntax errors.
|
||||||
|
|
||||||
cat > "$tmpfile"<<EOF
|
cat > "$tmpfile"<<EOF
|
||||||
;; This is line 1, and the next one is line 2.
|
;; This is line 1, and the next one is line 2.
|
||||||
(operating-system)
|
(operating-system)
|
||||||
|
@ -41,3 +43,36 @@ then
|
||||||
else
|
else
|
||||||
grep "$tmpfile:2:3:.*missing.* initializers" "$errorfile"
|
grep "$tmpfile:2:3:.*missing.* initializers" "$errorfile"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
# Reporting of duplicate service identifiers.
|
||||||
|
|
||||||
|
cat > "$tmpfile" <<EOF
|
||||||
|
(use-modules (gnu))
|
||||||
|
(use-service-modules networking)
|
||||||
|
|
||||||
|
(operating-system
|
||||||
|
(host-name "antelope")
|
||||||
|
(timezone "Europe/Paris")
|
||||||
|
(locale "en_US.UTF-8")
|
||||||
|
|
||||||
|
(bootloader (grub-configuration (device "/dev/sdX")))
|
||||||
|
(file-systems (cons (file-system
|
||||||
|
(device "root")
|
||||||
|
(title 'label)
|
||||||
|
(mount-point "/")
|
||||||
|
(type "ext4"))
|
||||||
|
%base-file-systems))
|
||||||
|
|
||||||
|
(services (cons* (dhcp-client-service)
|
||||||
|
(dhcp-client-service) ;twice!
|
||||||
|
%base-services)))
|
||||||
|
EOF
|
||||||
|
|
||||||
|
if guix system vm "$tmpfile" 2> "$errorfile"
|
||||||
|
then
|
||||||
|
# This must not succeed.
|
||||||
|
exit 1
|
||||||
|
else
|
||||||
|
grep "service 'networking'.*more than once" "$errorfile"
|
||||||
|
fi
|
||||||
|
|
Loading…
Reference in a new issue