Move base32 code to (guix base32).
[jackhill/guix/guix.git] / tests / base32.scm
CommitLineData
ddc29a78
LC
1;;; Guix --- Nix package management from Guile. -*- coding: utf-8 -*-
2;;; Copyright (C) 2012 Ludovic Courtès <ludo@gnu.org>
3;;;
4;;; This file is part of Guix.
5;;;
6;;; Guix is free software; you can redistribute it and/or modify it
7;;; under the terms of the GNU General Public License as published by
8;;; the Free Software Foundation; either version 3 of the License, or (at
9;;; your option) any later version.
10;;;
11;;; Guix is distributed in the hope that it will be useful, but
12;;; WITHOUT ANY WARRANTY; without even the implied warranty of
13;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14;;; GNU General Public License for more details.
15;;;
16;;; You should have received a copy of the GNU General Public License
17;;; along with Guix. If not, see <http://www.gnu.org/licenses/>.
18
19(define-module (test-base32)
20 #:use-module (guix base32)
21 #:use-module (guix utils)
22 #:use-module (srfi srfi-1)
23 #:use-module (srfi srfi-64)
24 #:use-module (ice-9 rdelim)
25 #:use-module (ice-9 popen)
26 #:use-module (rnrs bytevectors)
27 #:use-module (rnrs io ports))
28
29;; Test the (guix base32) module.
30
31(define %nix-hash
32 (or (getenv "NIX_HASH")
33 "nix-hash"))
34
35(test-begin "base32")
36
37(test-assert "bytevector->base32-string"
38 (fold (lambda (bv expected result)
39 (and result
40 (string=? (bytevector->base32-string bv)
41 expected)))
42 #t
43
44 ;; Examples from RFC 4648.
45 (map string->utf8 '("" "f" "fo" "foo" "foob" "fooba" "foobar"))
46 '(""
47 "my"
48 "mzxq"
49 "mzxw6"
50 "mzxw6yq"
51 "mzxw6ytb"
52 "mzxw6ytboi")))
53
54(test-assert "base32-string->bytevector"
55 (every (lambda (bv)
56 (equal? (base32-string->bytevector
57 (bytevector->base32-string bv))
58 bv))
59 ;; Examples from RFC 4648.
60 (map string->utf8 '("" "f" "fo" "foo" "foob" "fooba" "foobar"))))
61
62(test-assert "nix-base32-string->bytevector"
63 (every (lambda (bv)
64 (equal? (nix-base32-string->bytevector
65 (bytevector->nix-base32-string bv))
66 bv))
67 ;; Examples from RFC 4648.
68 (map string->utf8 '("" "f" "fo" "foo" "foob" "fooba" "foobar"))))
69
70;; The following tests requires `nix-hash' in $PATH.
71(test-skip (if (false-if-exception (system* %nix-hash "--version"))
72 0
73 1))
74
75(test-assert "sha256 & bytevector->nix-base32-string"
76 (let ((file (search-path %load-path "tests/test.drv")))
77 (equal? (bytevector->nix-base32-string
78 (sha256 (call-with-input-file file get-bytevector-all)))
79 (let* ((c (format #f "~a --type sha256 --base32 --flat \"~a\""
80 %nix-hash file))
81 (p (open-input-pipe c))
82 (l (read-line p)))
83 (close-pipe p)
84 l))))
85
86(test-end)
87
88\f
89(exit (= (test-runner-fail-count (test-runner-current)) 0))
90
91;;; Local Variables:
92;;; eval: (put 'test-assert 'scheme-indent-function 1)
93;;; End: