123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256 |
- ;;; GNU Guix --- Functional package management for GNU
- ;;; Copyright © 2015, 2017, 2022, 2023 Ricardo Wurmus <rekado@elephly.net>
- ;;; Copyright © 2016 Ben Woodcroft <donttrustben@gmail.com>
- ;;; Copyright © 2020 Martin Becze <mjbecze@riseup.net>
- ;;; Copyright © 2021 Sarah Morgensen <iskarian@mgsn.dev>
- ;;;
- ;;; 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/>.
- (define-module (test-import-utils)
- #:use-module (guix tests)
- #:use-module (guix import utils)
- #:use-module ((guix licenses) #:prefix license:)
- #:use-module (guix packages)
- #:use-module (guix build-system)
- #:use-module (gnu packages)
- #:use-module (srfi srfi-64)
- #:use-module (ice-9 match))
- (test-begin "import-utils")
- (test-equal "beautify-description: use double spacing"
- "\
- Trust me Mr. Hendrix, M. Night Shyamalan et al. \
- Differences are hard to spot,
- e.g. in CLOS vs. GOOPS."
- (beautify-description
- "
- Trust me Mr. Hendrix, M. Night Shyamalan et al. \
- Differences are hard to spot, e.g. in CLOS vs. GOOPS."))
- (test-equal "beautify-description: transform fragment into sentence"
- "This package provides a function to establish world peace"
- (beautify-description "A function to establish world peace"))
- (test-equal "beautify-description: remove single quotes"
- "CRAN likes to quote acronyms and function names."
- (beautify-description "CRAN likes to 'quote' acronyms and 'function' names."))
- (test-equal "beautify-description: escape @"
- "This @@ is not Texinfo syntax. Neither is this %@@>%."
- (beautify-description "This @ is not Texinfo syntax. Neither is this %@>%."))
- (test-equal "beautify-description: wrap PascalCase words in @code"
- "The term @code{DelayedMatrix} refers to a class."
- (beautify-description "The term DelayedMatrix refers to a class."))
- (test-equal "beautify-description: do not wrap acronyms in @code"
- "The term API is not code, but @code{myAPI} might be."
- (beautify-description "The term API is not code, but myAPI might be."))
- (test-equal "beautify-description: do not include punctuation when wrapping in @code"
- "Code (@code{DelayedMatrix}, @code{MaMa}, or @code{MeMe}) should be wrapped."
- (beautify-description "Code (DelayedMatrix, MaMa, or MeMe) should be wrapped."))
- (test-equal "license->symbol"
- 'license:lgpl2.0
- (license->symbol license:lgpl2.0))
- (test-equal "recursive-import"
- '((package ;package expressions in topological order
- (name "bar"))
- (package
- (name "foo")
- (inputs `(("bar" ,bar)))))
- (recursive-import "foo"
- #:repo 'repo
- #:repo->guix-package
- (match-lambda*
- (("foo" #:repo 'repo . rest)
- (values '(package
- (name "foo")
- (inputs `(("bar" ,bar))))
- '("bar")))
- (("bar" #:repo 'repo . rest)
- (values '(package
- (name "bar"))
- '())))
- #:guix-name identity))
- (test-equal "recursive-import: skip false packages (toplevel)"
- '()
- (recursive-import "foo"
- #:repo 'repo
- #:repo->guix-package
- (match-lambda*
- (("foo" #:repo 'repo . rest)
- (values #f '())))
- #:guix-name identity))
- (test-equal "recursive-import: skip false packages (dependency)"
- '((package
- (name "foo")
- (inputs `(("bar" ,bar)))))
- (recursive-import "foo"
- #:repo 'repo
- #:repo->guix-package
- (match-lambda*
- (("foo" #:repo 'repo . rest)
- (values '(package
- (name "foo")
- (inputs `(("bar" ,bar))))
- '("bar")))
- (("bar" #:repo 'repo . rest)
- (values #f '())))
- #:guix-name identity))
- (test-assert "alist->package with simple source"
- (let* ((meta '(("name" . "hello")
- ("version" . "2.10")
- ("source" .
- ;; Use a 'file://' URI so that we don't cause a download.
- ,(string-append "file://"
- (search-path %load-path "guix.scm")))
- ("build-system" . "gnu")
- ("home-page" . "https://gnu.org")
- ("synopsis" . "Say hi")
- ("description" . "This package says hi.")
- ("license" . "GPL-3.0+")))
- (pkg (alist->package meta)))
- (and (package? pkg)
- (license:license? (package-license pkg))
- (build-system? (package-build-system pkg))
- (origin? (package-source pkg)))))
- (test-assert "alist->package with explicit source"
- (let* ((meta '(("name" . "hello")
- ("version" . "2.10")
- ("source" . (("method" . "url-fetch")
- ("uri" . "mirror://gnu/hello/hello-2.10.tar.gz")
- ("sha256" .
- (("base32" .
- "0ssi1wpaf7plaswqqjwigppsg5fyh99vdlb9kzl7c9lng89ndq1i")))))
- ("build-system" . "gnu")
- ("home-page" . "https://gnu.org")
- ("synopsis" . "Say hi")
- ("description" . "This package says hi.")
- ("license" . "GPL-3.0+")))
- (pkg (alist->package meta)))
- (and (package? pkg)
- (license:license? (package-license pkg))
- (build-system? (package-build-system pkg))
- (origin? (package-source pkg))
- (equal? (content-hash-value (origin-hash (package-source pkg)))
- (base32 "0ssi1wpaf7plaswqqjwigppsg5fyh99vdlb9kzl7c9lng89ndq1i")))))
- (test-equal "alist->package with false license" ;<https://bugs.gnu.org/30470>
- 'license-is-false
- (let* ((meta '(("name" . "hello")
- ("version" . "2.10")
- ("source" . (("method" . "url-fetch")
- ("uri" . "mirror://gnu/hello/hello-2.10.tar.gz")
- ("sha256" .
- (("base32" .
- "0ssi1wpaf7plaswqqjwigppsg5fyh99vdlb9kzl7c9lng89ndq1i")))))
- ("build-system" . "gnu")
- ("home-page" . "https://gnu.org")
- ("synopsis" . "Say hi")
- ("description" . "This package says hi.")
- ("license" . #f))))
- ;; Note: Use 'or' because comparing with #f otherwise succeeds when
- ;; there's an exception instead of an actual #f.
- (or (package-license (alist->package meta))
- 'license-is-false)))
- (test-equal "alist->package with SPDX license name 1/2" ;<https://bugs.gnu.org/45453>
- license:expat
- (let* ((meta '(("name" . "hello")
- ("version" . "2.10")
- ("source" . (("method" . "url-fetch")
- ("uri" . "mirror://gnu/hello/hello-2.10.tar.gz")
- ("sha256" .
- (("base32" .
- "0ssi1wpaf7plaswqqjwigppsg5fyh99vdlb9kzl7c9lng89ndq1i")))))
- ("build-system" . "gnu")
- ("home-page" . "https://gnu.org")
- ("synopsis" . "Say hi")
- ("description" . "This package says hi.")
- ("license" . "expat"))))
- (package-license (alist->package meta))))
- (test-equal "alist->package with SPDX license name 2/2" ;<https://bugs.gnu.org/45453>
- license:expat
- (let* ((meta '(("name" . "hello")
- ("version" . "2.10")
- ("source" . (("method" . "url-fetch")
- ("uri" . "mirror://gnu/hello/hello-2.10.tar.gz")
- ("sha256" .
- (("base32" .
- "0ssi1wpaf7plaswqqjwigppsg5fyh99vdlb9kzl7c9lng89ndq1i")))))
- ("build-system" . "gnu")
- ("home-page" . "https://gnu.org")
- ("synopsis" . "Say hi")
- ("description" . "This package says hi.")
- ("license" . "MIT"))))
- (package-license (alist->package meta))))
- (test-equal "alist->package with dependencies"
- `(("gettext" ,(specification->package "gettext")))
- (let* ((meta '(("name" . "hello")
- ("version" . "2.10")
- ("source" . (("method" . "url-fetch")
- ("uri" . "mirror://gnu/hello/hello-2.10.tar.gz")
- ("sha256" .
- (("base32" .
- "0ssi1wpaf7plaswqqjwigppsg5fyh99vdlb9kzl7c9lng89ndq1i")))))
- ("build-system" . "gnu")
- ("home-page" . "https://gnu.org")
- ("synopsis" . "Say hi")
- ("description" . "This package says hi.")
- ;
- ;; Note: As with Guile-JSON 3.x, JSON arrays are represented
- ;; by vectors.
- ("native-inputs" . #("gettext"))
- ("license" . #f))))
- (package-native-inputs (alist->package meta))))
- (test-assert "alist->package with properties"
- (let* ((meta '(("name" . "hello")
- ("version" . "2.10")
- ("source" .
- ;; Use a 'file://' URI so that we don't cause a download.
- ,(string-append "file://"
- (search-path %load-path "guix.scm")))
- ("build-system" . "gnu")
- ("properties" . (("hidden?" . #t)
- ("upstream-name" . "hello-upstream")))
- ("home-page" . "https://gnu.org")
- ("synopsis" . "Say hi")
- ("description" . "This package says hi.")
- ("license" . "GPL-3.0+")))
- (pkg (alist->package meta)))
- (and (package? pkg)
- (equal? (package-upstream-name pkg) "hello-upstream")
- (hidden-package? pkg))))
- (test-equal "spdx-string->license"
- '(license:gpl3+ license:agpl3 license:gpl2+)
- (map spdx-string->license
- '("GPL-3.0-oR-LaTeR" "AGPL-3.0" "GPL-2.0+")))
- (test-end "import-utils")
|