;;; GNU Guix --- Functional package management for GNU ;;; Copyright © 2015 Federico Beffa ;;; Copyright © 2020, 2023 Ludovic Courtès ;;; Copyright © 2020 Martin Becze ;;; Copyright © 2021 Xinglu Chen ;;; ;;; 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-elpa) #:use-module (guix import elpa) #:use-module (guix upstream) #:use-module ((guix download) #:select (url-fetch)) #:use-module (guix tests) #:use-module (guix tests http) #:use-module (srfi srfi-1) #:use-module (srfi srfi-64) #:use-module (ice-9 match) #:use-module (web client)) (define elpa-mock-archive '(1 (ace-window . [(0 9 0) ((avy (0 2 0))) "Quickly switch windows." single ((:url . "https://github.com/abo-abo/ace-window") (:keywords "window" "location"))]) (auctex . [(11 88 6) nil "Integrated environment for *TeX*" tar ((:url . "http://www.gnu.org/software/auctex/"))]) (fake-taxy-magit-section . [(0 12 2) ((emacs (26 3)) (magit-section (3 2 1)) (taxy (0 10))) "View Taxy structs i;;; GNU Guix --- Functional package management for GNU ;;; Copyright © 2015 Alex Kost <alezost@gmail.com> ;;; ;;; 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 <http://www.gnu.org/licenses/>. ;;; ;;; Generate AUTHORS file for directory with the Guix git repository. ;;; (use-modules (ice-9 popen) (ice-9 rdelim) (ice-9 match) (srfi srfi-1) (guix config) (guix utils) (guix build utils)) (define %guix-dir (make-parameter #f)) (define-syntax-rule (append-maybe init-lst (test add-lst) ...) (let* ((lst init-lst) (lst (if test (append lst add-lst) lst)) ...) lst)) (define (command-output cmd . args) "Execute CMD with ARGS and return its output without trailing newspace." (let* ((port (apply open-pipe* OPEN_READ cmd args)) (output (read-string port))) (close-port port) (string-trim-right output #\newline))) (define (git-output . args) "Execute git command with ARGS and return its output without trailing newspace." (with-directory-excursion (%guix-dir) (apply command-output "git" args))) (define* (contributors-string #:optional (range "HEAD")) "Return a string with names of people contributed to commit RANGE." (git-output "shortlog" "--numbered" "--summary" "--email" range)) (define* (tags #:key pattern sort) "Return a list of the git repository tags. PATTERN is passed to '--list' and SORT is passed to '--sort' options of 'git tag' command." (let* ((args (append-maybe '("tag") (pattern (list "--list" pattern)) (sort (list "--sort" sort)))) (output (apply git-output args))) (string-split output #\newline))) (define (version-tags) "Return only version tags (v0.8, etc.) sorted from the biggest version to the smallest one." (tags #:pattern "v*" #:sort "-version:refname")) (define (generate-authors-file file) "Generate authors FILE." (define previous-release-tag (find (lambda (tag) (version>? %guix-version (substring tag 1))) ; remove leading 'v' (version-tags))) (define release-range (string-append previous-release-tag "..HEAD"))