all messages for Guix-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
blob 71f33691fcac3bc4a721830194d0ae59ed184054 4305 bytes (raw)
name: build-aux/cuirass/gnu-system.scm 	 # note: path name is non-authoritative(*)

  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
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
 
;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2012, 2013, 2014, 2015, 2016, 2017, 2018, 2020 Ludovic Courtès <ludo@gnu.org>
;;; Copyright © 2017 Jan Nieuwenhuizen <janneke@gnu.org>
;;; Copyright © 2018, 2019 Clément Lassieur <clement@lassieur.org>
;;; Copyright © 2021 Mathieu Othacehe <othacehe@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/>.

;;;
;;; This file defines build jobs for the Cuirass continuation integration
;;; tool.
;;;

(use-modules (guix inferior) (guix channels)
             (guix)
             (guix ui)
             (srfi srfi-1)
             (ice-9 match)
             (ice-9 threads))

;; XXX: Debugging hack: since `hydra-eval-guile-jobs' redirects the output
;; port to the bit bucket, let us write to the error port instead.
(setvbuf (current-error-port) 'line)
(set-current-output-port (current-error-port))

(define (find-current-checkout arguments)
  "Find the first checkout of ARGUMENTS that provided the current file.
Return #f if no such checkout is found."
  (let ((current-root
         (canonicalize-path
          (string-append (dirname (current-filename)) "/../.."))))
    (find (lambda (argument)
            (and=> (assq-ref argument 'file-name)
                   (lambda (name)
                     (string=? name current-root)))) arguments)))

(define* (cuirass-jobs store arguments register)
  "Return a list of jobs where each job is a NAME/THUNK pair."

  (define checkout
    (find-current-checkout arguments))

  (define commit
    (assq-ref checkout 'revision))

  (define source
    (assq-ref checkout 'file-name))

  (define instance
    (checkout->channel-instance source #:commit commit))

  (define derivation
    ;; Compute the derivation of Guix for COMMIT.
    (run-with-store store
      (channel-instances->derivation (list instance))))

  ;; TODO: Remove 'show-what-to-build' call when Cuirass' 'evaluate' scripts
  ;; uses 'with-build-handler'.
  (show-what-to-build store (list derivation))
  (build-derivations store (list derivation))

  ;; Open an inferior for the just-built Guix.
  (call-with-temporary-directory
   (lambda (directory)
     (let* ((name (string-append directory "/ci-inferior"))
            (socket (socket AF_UNIX SOCK_STREAM 0))
            (inferior (open-inferior (derivation->output-path derivation))))

       ;; XXX: The inferior cannot call directly the register procedure that
       ;; is declared in Cuirass.  Use a socket to proxy the inferior
       ;; registration requests.
       (call-with-new-thread
        (lambda ()
          (bind socket AF_UNIX name)
          (listen socket 1024)
          (match (select (list socket) '() '() 60)
            (((_) () ())
             (match (accept socket)
               ((client . address)
                (setvbuf client 'block 1024)
                (let loop ((exp (read client)))
                  (unless (eof-object? exp)
                    (apply register exp)
                    (loop (read client)))))))
            ((() () ())
             #f))
          (close-port socket)))

       (inferior-eval '(use-modules (gnu ci) (ice-9 match)) inferior)
       (inferior-eval-with-store
        inferior store
        `(lambda (store)
           (let* ((socket (socket AF_UNIX SOCK_STREAM 0))
                  (register (lambda args
                              (write args socket))))
             (connect socket AF_UNIX ,name)
             (setvbuf socket 'block 1024)
             (cuirass-jobs store '((superior-guix-checkout . ,checkout)
                                   ,@arguments)
                           register)
             (close-port socket))))))))

debug log:

solving 71f33691fc ...
found 71f33691fc in https://yhetil.org/guix/87h7mbgk6e.fsf@gnu.org/
found 0eb834cfba in https://git.savannah.gnu.org/cgit/guix.git
preparing index
index prepared:
100644 0eb834cfba12c1a3113371e064ff0f690affaf69	build-aux/cuirass/gnu-system.scm

applying [1/1] https://yhetil.org/guix/87h7mbgk6e.fsf@gnu.org/
diff --git a/build-aux/cuirass/gnu-system.scm b/build-aux/cuirass/gnu-system.scm
index 0eb834cfba..71f33691fc 100644

Checking patch build-aux/cuirass/gnu-system.scm...
Applied patch build-aux/cuirass/gnu-system.scm cleanly.

index at:
100644 71f33691fcac3bc4a721830194d0ae59ed184054	build-aux/cuirass/gnu-system.scm

(*) Git path names are given by the tree(s) the blob belongs to.
    Blobs themselves have no identifier aside from the hash of its contents.^

Code repositories for project(s) associated with this external index

	https://git.savannah.gnu.org/cgit/guix.git

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.