aboutsummaryrefslogtreecommitdiff
path: root/tests/cpio.scm
blob: 832101d1bbfb751087d46e4bccddecc600568daa (about) (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2015, 2022 Ludovic Courtès <ludo@gnu.org>
;;;
;;; 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-cpio)
  #:use-module (guix cpio)
  #:use-module (guix tests)
  #:use-module ((guix build utils) #:select (which))
  #:use-module ((guix utils) #:select (call-with-temporary-output-file))
  #:use-module (ice-9 match)
  #:use-module (ice-9 popen)
  #:use-module (rnrs io ports)
  #:use-module (srfi srfi-1)
  #:use-module (srfi srfi-26)
  #:use-module (srfi srfi-64))

(define %cpio-program
  (which "cpio"))

(define %test-file
  (search-path %load-path "guix.scm"))


(test-begin "cpio")

;; The cpio format expects 'ino' to fit in 32 bits.  If we have a bigger inode
;; number, skip this test.
(test-skip
 (if (>= (stat:ino (lstat %test-file)) (expt 2 32)) 1 0))
(test-assert "file->cpio-header + write-cpio-header + read-cpio-header"
  (let* ((header (file->cpio-header %test-file)))
    (call-with-values
        (lambda ()
          (open-bytevector-output-port))
      (lambda (port get-bv)
        (write-cpio-header header port)
        (let ((port (open-bytevector-input-port (get-bv))))
          (equal? header (read-cpio-header port)))))))

(unless %cpio-program (test-skip 1))
(test-assert "bit-identical to GNU cpio's output"
  (call-with-temporary-output-file
   (lambda (link _)
     (delete-file link)
     (symlink "chbouib" link)

     (let ((files (cons* "/"
                         (canonicalize-path
                          (dirname (search-path %load-path "guix.scm")))
                         link
                         (map (compose canonicalize-path
                                       (cut search-path %load-path <>))
                              '("guix.scm" "guix/build/syscalls.scm"
                                "guix/packages.scm")))))
       (call-with-temporary-output-file
        (lambda (ref-file _)
          (let ((pipe (open-pipe* OPEN_WRITE %cpio-program "-o" "-O" ref-file
                                  "-H" "newc" "--null")))
            (for-each (lambda (file)
                        (format pipe "~a\0" file))
                      files)
            (and (zero? (close-pipe pipe))
                 (call-with-temporary-output-file
                  (lambda (file port)
                    (write-cpio-archive files port)
                    (close-port port)
                    (or (file=? ref-file file)
                        (throw 'cpio-archives-differ files
                               ref-file file
                               (stat:size (stat ref-file))
                               (stat:size (stat file))))))))))))))

(test-end "cpio")
=b45acc342e883c04b1c7a4d9ab74c40a7ae4acbc'>plainabout -rw-r--r--cpio.scm3154logplainabout -rw-r--r--cran.scm5041logplainabout -rw-r--r--crate.scm3334logplainabout -rw-r--r--cve-sample.xml43360logplainabout -rw-r--r--cve.scm2321logplainabout -rw-r--r--debug-link.scm6709logplainabout -rw-r--r--derivations.scm57708logplainabout -rw-r--r--discovery.scm2540logplainabout -rw-r--r--elpa.scm3925logplainabout -rw-r--r--file-systems.scm2686logplainabout -rw-r--r--gem.scm6518logplainabout -rw-r--r--gexp.scm56604logplainabout -rw-r--r--glob.scm2331logplainabout -rw-r--r--gnu-maintenance.scm1688logplainabout -rw-r--r--grafts.scm22788logplainabout -rw-r--r--graph.scm16991logplainabout -rw-r--r--gremlin.scm3478logplainabout -rw-r--r--guix-archive.sh2656logplainabout -rw-r--r--guix-authenticate.sh2963logplainabout -rw-r--r--guix-build-branch.sh1973logplainabout -rw-r--r--guix-build.sh8051logplainabout -rw-r--r--guix-daemon.sh7820logplainabout -rw-r--r--guix-describe.sh1405logplainabout -rw-r--r--guix-download.sh1593logplainabout -rw-r--r--guix-environment-container.sh5286logplainabout -rw-r--r--guix-environment.sh8345logplainabout -rw-r--r--guix-gc.sh2749logplainabout -rw-r--r--guix-graph.sh1812logplainabout -rw-r--r--guix-hash.sh2266logplainabout -rw-r--r--guix-lint.sh2276logplainabout -rw-r--r--guix-pack-localstatedir.sh2538logplainabout -rw-r--r--guix-pack-relocatable.sh2718logplainabout -rw-r--r--guix-pack.sh3841logplainabout -rw-r--r--guix-package-net.sh7289logplainabout -rw-r--r--guix-package.sh12857logplainabout -rw-r--r--guix-system.sh8515logplainabout -rw-r--r--hackage.scm6639logplainabout -rw-r--r--import-utils.scm4390logplainabout -rw-r--r--inferior.scm9657logplainabout -rw-r--r--lint.scm33081logplainabout -rw-r--r--modules.scm2582logplainabout -rw-r--r--monads.scm9099logplainabout -rw-r--r--nar.scm18645logplainabout -rw-r--r--opam.scm7872logplainabout -rw-r--r--pack.scm10132logplainabout -rw-r--r--packages.scm55742logplainabout -rw-r--r--pki.scm5220logplainabout -rw-r--r--print.scm2133logplainabout -rw-r--r--processes.scm3559logplainabout -rw-r--r--profiles.scm28506logplainabout -rw-r--r--publish.scm20025logplainabout -rw-r--r--pypi.scm8276logplainabout -rw-r--r--records.scm14053logplainabout -rw-r--r--scripts-build.scm12015logplainabout -rw-r--r--scripts.scm2034logplainabout -rw-r--r--search-paths.scm1765logplainabout -rw-r--r--services.scm11601logplainabout -rw-r--r--sets.scm1507logplainabout -rw-r--r--signing-key.pub302logplainabout -rw-r--r--signing-key.sec983logplainabout -rw-r--r--size.scm4576logplainabout -rw-r--r--snix.scm2504logplainabout -rw-r--r--status.scm12235logplainabout -rw-r--r--store-database.scm3718logplainabout -rw-r--r--store-deduplication.scm4533logplainabout -rw-r--r--store.scm49370logplainabout -rw-r--r--substitute.scm19754logplainabout -rw-r--r--syscalls.scm19357logplainabout -rw-r--r--system.scm5143logplainabout -rw-r--r--test.drv5922logplainabout -rw-r--r--texlive.scm4413logplainabout -rw-r--r--ui.scm7577logplainabout -rw-r--r--union.scm9548logplainabout -rw-r--r--upstream.scm1963logplainabout -rw-r--r--utils.scm8689logplainabout -rw-r--r--uuid.scm2574logplainabout -rw-r--r--workers.scm2172logplainabout -rw-r--r--zlib.scm2228logplainabout