utils.scm 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. ;;; GNU Guix --- Functional package management for GNU
  2. ;;; Copyright © 2012, 2013, 2014, 2015, 2016, 2017 Ludovic Courtès <ludo@gnu.org>
  3. ;;; Copyright © 2014 Eric Bavier <bavier@member.fsf.org>
  4. ;;; Copyright © 2016 Mathieu Lirzin <mthl@gnu.org>
  5. ;;;
  6. ;;; This file is part of GNU Guix.
  7. ;;;
  8. ;;; GNU Guix is free software; you can redistribute it and/or modify it
  9. ;;; under the terms of the GNU General Public License as published by
  10. ;;; the Free Software Foundation; either version 3 of the License, or (at
  11. ;;; your option) any later version.
  12. ;;;
  13. ;;; GNU Guix is distributed in the hope that it will be useful, but
  14. ;;; WITHOUT ANY WARRANTY; without even the implied warranty of
  15. ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. ;;; GNU General Public License for more details.
  17. ;;;
  18. ;;; You should have received a copy of the GNU General Public License
  19. ;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
  20. (define-module (test-utils)
  21. #:use-module ((guix config) #:select (%gzip))
  22. #:use-module (guix utils)
  23. #:use-module ((guix store) #:select (%store-prefix store-path-package-name))
  24. #:use-module ((guix search-paths) #:select (string-tokenize*))
  25. #:use-module (srfi srfi-1)
  26. #:use-module (srfi srfi-11)
  27. #:use-module (srfi srfi-64)
  28. #:use-module (rnrs bytevectors)
  29. #:use-module (rnrs io ports)
  30. #:use-module (ice-9 match)
  31. #:use-module (ice-9 vlist))
  32. (define temp-file
  33. (string-append "t-utils-" (number->string (getpid))))
  34. (test-begin "utils")
  35. (test-assert "gnu-triplet->nix-system"
  36. (let ((samples '(("i586-gnu0.3" "i686-gnu")
  37. ("x86_64-unknown-linux-gnu" "x86_64-linux")
  38. ("i386-pc-linux-gnu" "i686-linux")
  39. ("x86_64-unknown-freebsd8.2" "x86_64-freebsd")
  40. ("x86_64-apple-darwin10.8.0" "x86_64-darwin")
  41. ("i686-pc-cygwin" "i686-cygwin"))))
  42. (let-values (((gnu nix) (unzip2 samples)))
  43. (every (lambda (gnu nix)
  44. (equal? nix (gnu-triplet->nix-system gnu)))
  45. gnu nix))))
  46. (test-assert "package-name->name+version"
  47. (every (match-lambda
  48. ((name version)
  49. (let*-values (((full-name)
  50. (if version
  51. (string-append name "@" version)
  52. name))
  53. ((name* version*)
  54. (package-name->name+version full-name)))
  55. (and (equal? name* name)
  56. (equal? version* version)))))
  57. '(("foo" "0.9.1b")
  58. ("foo-14-bar" "320")
  59. ("foo-bar2" #f)
  60. ("guile" "2.0.6.65-134c9") ; as produced by `git-version-gen'
  61. ("nixpkgs" "1.0pre22125_a28fe19")
  62. ("gtk2" "2.38.0"))))
  63. (test-assert "guile-version>? 1.8"
  64. (guile-version>? "1.8"))
  65. (test-assert "guile-version>? 10.5"
  66. (not (guile-version>? "10.5")))
  67. (test-equal "string-tokenize*"
  68. '(("foo")
  69. ("foo" "bar" "baz")
  70. ("foo" "bar" "")
  71. ("foo" "bar" "baz"))
  72. (list (string-tokenize* "foo" ":")
  73. (string-tokenize* "foo;bar;baz" ";")
  74. (string-tokenize* "foo!bar!" "!")
  75. (string-tokenize* "foo+-+bar+-+baz" "+-+")))
  76. (test-equal "string-replace-substring"
  77. '("foo BAR! baz"
  78. "/gnu/store/chbouib"
  79. "")
  80. (list (string-replace-substring "foo bar baz" "bar" "BAR!")
  81. (string-replace-substring "/nix/store/chbouib" "/nix/" "/gnu/")
  82. (string-replace-substring "" "foo" "bar")))
  83. (test-equal "strip-keyword-arguments"
  84. '(a #:b b #:c c)
  85. (strip-keyword-arguments '(#:foo #:bar #:baz)
  86. '(a #:foo 42 #:b b #:baz 3
  87. #:c c #:bar 4)))
  88. (test-equal "ensure-keyword-arguments"
  89. '((#:foo 2)
  90. (#:foo 2 #:bar 3)
  91. (#:foo 42 #:bar 3))
  92. (list (ensure-keyword-arguments '(#:foo 2) '(#:foo 2))
  93. (ensure-keyword-arguments '(#:foo 2) '(#:bar 3))
  94. (ensure-keyword-arguments '(#:foo 2) '(#:bar 3 #:foo 42))))
  95. (test-equal "default-keyword-arguments"
  96. '((#:foo 2)
  97. (#:foo 2)
  98. (#:foo 2 #:bar 3)
  99. (#:foo 2 #:bar 3)
  100. (#:foo 2 #:bar 3))
  101. (list (default-keyword-arguments '() '(#:foo 2))
  102. (default-keyword-arguments '(#:foo 2) '(#:foo 4))
  103. (default-keyword-arguments '() '(#:bar 3 #:foo 2))
  104. (default-keyword-arguments '(#:bar 3) '(#:foo 2))
  105. (default-keyword-arguments '(#:foo 2 #:bar 3) '(#:bar 6))))
  106. (test-equal "substitute-keyword-arguments"
  107. '((#:foo 3)
  108. (#:foo 3)
  109. (#:foo 3 #:bar (1 2))
  110. (#:bar (1 2) #:foo 3)
  111. (#:foo 3))
  112. (list (substitute-keyword-arguments '(#:foo 2)
  113. ((#:foo f) (1+ f)))
  114. (substitute-keyword-arguments '()
  115. ((#:foo f 2) (1+ f)))
  116. (substitute-keyword-arguments '(#:foo 2 #:bar (2))
  117. ((#:foo f) (1+ f))
  118. ((#:bar b) (cons 1 b)))
  119. (substitute-keyword-arguments '(#:foo 2)
  120. ((#:foo _) 3)
  121. ((#:bar b '(2)) (cons 1 b)))
  122. (substitute-keyword-arguments '(#:foo 2)
  123. ((#:foo f 1) (1+ f))
  124. ((#:bar b) (cons 42 b)))))
  125. (test-assert "filtered-port, file"
  126. (let* ((file (search-path %load-path "guix.scm"))
  127. (input (open-file file "r0b")))
  128. (let*-values (((compressed pids1)
  129. (filtered-port `(,%gzip "-c" "--fast") input))
  130. ((decompressed pids2)
  131. (filtered-port `(,%gzip "-d") compressed)))
  132. (and (every (compose zero? cdr waitpid)
  133. (append pids1 pids2))
  134. (equal? (get-bytevector-all decompressed)
  135. (call-with-input-file file get-bytevector-all))))))
  136. (test-assert "filtered-port, non-file"
  137. (let ((data (call-with-input-file (search-path %load-path "guix.scm")
  138. get-bytevector-all)))
  139. (let*-values (((compressed pids1)
  140. (filtered-port `(,%gzip "-c" "--fast")
  141. (open-bytevector-input-port data)))
  142. ((decompressed pids2)
  143. (filtered-port `(,%gzip "-d") compressed)))
  144. (and (pk (every (compose zero? cdr waitpid)
  145. (append pids1 pids2)))
  146. (equal? (get-bytevector-all decompressed) data)))))
  147. (test-assert "filtered-port, does not exist"
  148. (let* ((file (search-path %load-path "guix.scm"))
  149. (input (open-file file "r0b")))
  150. (let-values (((port pids)
  151. (filtered-port '("/does/not/exist") input)))
  152. (any (compose (negate zero?) cdr waitpid)
  153. pids))))
  154. (test-assert "compressed-port, decompressed-port, non-file"
  155. (let ((data (call-with-input-file (search-path %load-path "guix.scm")
  156. get-bytevector-all)))
  157. (let*-values (((compressed pids1)
  158. (compressed-port 'xz (open-bytevector-input-port data)))
  159. ((decompressed pids2)
  160. (decompressed-port 'xz compressed)))
  161. (and (every (compose zero? cdr waitpid)
  162. (append pids1 pids2))
  163. (equal? (get-bytevector-all decompressed) data)))))
  164. (false-if-exception (delete-file temp-file))
  165. (test-assert "compressed-output-port + decompressed-port"
  166. (let* ((file (search-path %load-path "guix/derivations.scm"))
  167. (data (call-with-input-file file get-bytevector-all))
  168. (port (open-file temp-file "w0b")))
  169. (call-with-compressed-output-port 'xz port
  170. (lambda (compressed)
  171. (put-bytevector compressed data)))
  172. (close-port port)
  173. (bytevector=? data
  174. (call-with-decompressed-port 'xz (open-file temp-file "r0b")
  175. get-bytevector-all))))
  176. ;; This is actually in (guix store).
  177. (test-equal "store-path-package-name"
  178. "bash-4.2-p24"
  179. (store-path-package-name
  180. (string-append (%store-prefix)
  181. "/qvs2rj2ia5vci3wsdb7qvydrmacig4pg-bash-4.2-p24")))
  182. (test-equal "canonical-newline-port"
  183. "This is a journey\nInto the sound\nA journey ...\n"
  184. (let ((port (open-string-input-port
  185. "This is a journey\r\nInto the sound\r\nA journey ...\n")))
  186. (get-string-all (canonical-newline-port port))))
  187. (test-equal "edit-expression"
  188. "(display \"GNU Guix\")\n(newline)\n"
  189. (begin
  190. (call-with-output-file temp-file
  191. (lambda (port)
  192. (display "(display \"xiuG UNG\")\n(newline)\n" port)))
  193. (edit-expression `((filename . ,temp-file)
  194. (line . 0)
  195. (column . 9))
  196. string-reverse)
  197. (call-with-input-file temp-file get-string-all)))
  198. (test-end)
  199. (false-if-exception (delete-file temp-file))