;;; GNU Guix --- Functional package management for GNU ;;; Copyright © 2023 Maxim Cournoyer ;;; ;;; This file is part of GNU Guix. ;;; ;;; GNU Guix 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. ;;; ;;; GNU Guix 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 GNU Guix. If not, see . (define-module (test-rpm) #:use-module (guix rpm) #:use-module (rnrs bytevectors) #:use-module (srfi srfi-1) #:use-module (srfi srfi-26) #:use-module (srfi srfi-64) #:use-module (srfi srfi-71)) ;; For white-box testing. (define-syntax-rule (expose-internal name) (define name (@@ (guix rpm) name))) (expose-internal RPMTAG_ARCH) (expose-internal RPMTAG_LICENSE) (expose-internal RPMTAG_NAME) (expose-internal RPMTAG_OS) (expose-internal RPMTAG_RELEASE) (expose-internal RPMTAG_SUMMARY) (expose-internal RPMTAG_VERSION) (expose-internal header-entry-count) (expose-internal header-entry-tag) (expose-internal header-entry-value) (expose-internal header-entry?) (expose-internal make-header) (expose-internal make-header-entry) (expose-internal make-header-index+data) (test-begin "rpm") (test-equal "lead must be 96 bytes long" 96 (length (generate-lead "hello-2.12.1"))) (define header-entries (list (make-header-entry RPMTAG_NAME 1 "hello") (make-header-entry RPMTAG_VERSION 1 "2.12.1") (make-header-entry RPMTAG_RELEASE 1 "0") (make-header-entry RPMTAG_SUMMARY 1 "Hello, GNU world: An example GNU package") (make-header-entry RPMTAG_LICENSE 1 "GPL 3 or later") (make-header-entry RPMTAG_OS 1 "Linux") (make-header-entry RPMTAG_ARCH 1 "x86_64"))) (define expected-header-index-length (* 16 (length header-entries))) ;16 bytes per index entry (define expected-header-data-length (+ (length header-entries) ;to account for null bytes (fold + 0 (map (compose string-length (cut header-entry-value <>)) header-entries)))) (let ((index data (make-header-index+data header-entries))) (test-equal "header index" expected-header-index-length (length index)) ;; This test depends on the fact that only STRING entries are used, and that ;; they are composed of single byte characters and the delimiting null byte. (test-equal "header data" expected-header-data-length (length data))) (test-equal "complete header section" (+ 16 ;leading magic + count bytes expected-header-index-length expected-header-data-length) (length (make-header header-entries))) (test-end) 010b970226f85b7a5 Zheng Junjie 2024-03-19services: sddm: Add extension for localed-service-type....* gnu/services/sddm.scm (sddm-service-type): Add extension for localed-service-type. * gnu/services/xorg.scm (xorg-configuration-keyboard-layout): Export it. Change-Id: I26e6475b733d69f1baf00786e302a3ec6d3c4a74 Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02services: sddm: Set some environment variables for the breeze theme....* gnu/services/sddm.scm (sddm-service-type): Pass #:environment-variables to make-forkexec-constructor. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie