aboutsummaryrefslogtreecommitdiff
path: root/tests/jobs-load-new-guix-revision.scm
blob: 14d0e3342b09e3110fb37fe164a36c7a18459eab (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
88
(define-module (tests jobs-load-new-guix-revision)
  #:use-module (srfi srfi-64)
  #:use-module (ice-9 match)
  #:use-module (squee)
  #: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 git-repository)
  #:use-module (guix-data-service jobs load-new-guix-revision))

(test-begin "jobs-load-new-guix-revision")

(with-postgresql-connection
 "test-jobs-load-new-guix-revision"
 (lambda (conn)
   (test-equal "select-job-for-commit works"
     '()
     (select-job-for-commit conn "does not exist"))

   (test-equal "test job success"
     #t
     (mock
      ((guix-data-service jobs load-new-guix-revision)
       store-item-for-git-repository-id-and-commit
       (lambda (conn git-repository-id commit)
         "/gnu/store/test"))

      (mock
       ((guix-data-service jobs load-new-guix-revision)
        extract-information-from
        (lambda (conn git-repository-id commit store-path)
          #t))

       (match (enqueue-load-new-guix-revision-job
               conn
               (git-repository-url->git-repository-id conn "test-url")
               "test-commit"
               "test-source")
         ((id)
          (process-load-new-guix-revision-job id))))))

   (exec-query conn "TRUNCATE load_new_guix_revision_jobs CASCADE")

   (test-equal "test build store item failure"
     #f
     (mock
      ((guix-data-service jobs load-new-guix-revision)
       store-item-for-git-repository-id-and-commit
       (lambda (conn git-repository-id commit)
         #f))

      (match (enqueue-load-new-guix-revision-job
              conn
              (git-repository-url->git-repository-id conn "test-url")
              "test-commit"
              "test-source")
        ((id)
         (process-load-new-guix-revision-job id)))))

   (exec-query conn "TRUNCATE load_new_guix_revision_jobs CASCADE")

   (test-equal "test extract information failure"
     #f
     (mock
      ((guix-data-service jobs load-new-guix-revision)
       store-item-for-git-repository-id-and-commit
       (lambda (conn git-repository-id commit)
         "/gnu/store/test"))

      (mock
       ((guix-data-service jobs load-new-guix-revision)
        extract-information-from
        (lambda (conn git-repository-id commit store-path)
          #f))

       (match (enqueue-load-new-guix-revision-job
               conn
               (git-repository-url->git-repository-id conn "test-url")
               "test-commit"
               "test-source")
         ((id)
          (process-load-new-guix-revision-job id))))))

   (exec-query conn "TRUNCATE load_new_guix_revision_jobs CASCADE")))


(test-end)