aboutsummaryrefslogtreecommitdiff
path: root/tests/model-license-set.scm
blob: fecf242f6d17153ff605eb6f1020d6938f87a3a7 (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
 (define-module (tests model-license-set)
  #:use-module (srfi srfi-64)
  #:use-module (guix utils)
  #:use-module (guix tests)
  #:use-module (guix-data-service database)
  #:use-module (tests mock-inferior)
  #:use-module (guix-data-service model license-set))

(use-modules (tests driver))

(test-begin "test-model-license-set")

(mock
 ((guix-data-service model license)
  inferior-packages->license-data
  (lambda (inf packages)
    '((("License 1"
        "https://gnu.org/licenses/test-1.html"
        "https://example.com/why-license-1"))
      (("License 1"
        "https://gnu.org/licenses/test-1.html"
        "https://example.com/why-license-1")
       ("License 2"
        "https://gnu.org/licenses/test-2.html"
        "https://example.com/why-license-2")))))

 (with-postgresql-connection
  (lambda (conn)
    (with-postgresql-transaction
     conn
     (lambda (conn)
       (test-assert "works"
         (inferior-packages->license-set-ids conn #f #f)))
     #:always-rollback? #t)

    (with-postgresql-transaction
     conn
     (lambda (conn)
       (test-equal "works repeatedly"
         (inferior-packages->license-set-ids conn #f #f)
         (inferior-packages->license-set-ids conn #f #f)))
     #:always-rollback? #t))))

(test-end)