;;; GNU Guix --- Functional package management for GNU ;;; Copyright © 2015 David Thompson ;;; ;;; 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-gem) #:use-module (guix import gem) #:use-module (guix base32) #:use-module (guix hash) #:use-module (guix tests) #:use-module ((guix build utils) #:select (delete-file-recursively)) #:use-module (srfi srfi-64) #:use-module (ice-9 match)) (define test-json "{ \"name\": \"foo\", \"version\": \"1.0.0\", \"sha\": \"f3676eafca9987cb5fe263df1edf2538bf6dafc712b30e17be3543a9680547a8\", \"info\": \"A cool gem\", \"homepage_uri\": \"https://example.com\", \"dependencies\": { \"runtime\": [ { \"name\": \"bundler\" }, { \"name\": \"bar\" } ] }, \"licenses\": [\"MIT\", \"Apache 2.0\"] }") (test-begin "gem") (test-assert "gem->guix-package" ;; Replace network resources with sample data. (mock ((guix import utils) url-fetch (lambda (url file-name) (match url ("https://rubygems.org/api/v1/gems/foo.json" (with-output-to-file file-name (lambda () (display test-json)))) (_ (error "Unexpected URL: " url))))) (match (gem->guix-package "foo") (('package ('name "ruby-foo") ('version "1.0.0") ('source ('origin ('method 'url-fetch) ('uri ('rubygems-uri "foo" 'version)) ('sha256 ('base32 "1a270mlajhrmpqbhxcqjqypnvgrq4pgixpv3w9gwp1wrrapnwrzk")))) ('build-system 'ruby-build-system) ('propagated-inputs ('quasiquote (("bundler" ('unquote 'bundler)) ("ruby-bar" ('unquote 'ruby-bar))))) ('synopsis "A cool gem") ('description "A cool gem") ('home-page "https://example.com") ('license ('list 'expat 'asl2.0))) #t) (x (pk 'fail x #f))))) (test-end "gem") (exit (= (test-runner-fail-count (test-runner-current)) 0)) mp in Docker images....Ludovic Courtès 2019-03-24tests: Adjust 'guix pack -f squashfs' test....Ludovic Courtès 2018-11-06store-copy: Canonicalize the mtime and permissions of the store copy....Ludovic Courtès 2018-11-06pack: Add test for 'self-contained-tarball' with localstatedir....Ludovic Courtès 2018-11-06pack: Squashfs backend now honors '--localstatedir'....Ludovic Courtès 2018-11-06pack: Docker backend now honors '--localstatedir'....Ludovic Courtès 2018-11-06pack: Import (guix store database) only when '--localstatedir' is passed....Ludovic Courtès 2018-10-28tests: Fix typo....Ludovic Courtès 2018-10-19tests: Run 'guix pack' tests using the external store....Ludovic Courtès 2018-09-18tests: Skip 'self-contained-tarball' test unconditionally....Ludovic Courtès 2018-06-01pack: Adjust test to expect relative symlinks....Ludovic Courtès 2018-06-01tests: Fix arguments in pack test....Ricardo Wurmus 2017-03-22tests: Skip 'guix pack' test when networking is unavailable....Ludovic Courtès 2017-03-17pack: Move absolute file name to <compressor>....Ludovic Courtès 2017-03-14pack: Add unit test....Ludovic Courtès