aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorArun Isaac2022-02-08 23:59:16 +0530
committerArun Isaac2022-02-09 11:37:01 +0530
commit2e72b4c4e1bee27b260d1a925b3c103e1e1a7cda (patch)
tree93b3991b716a6f71f9491459489cd7b43576097c
parentc1837714c0dd2cf12d914d1236083e6f04aa0012 (diff)
downloadguix-forge-2e72b4c4e1bee27b260d1a925b3c103e1e1a7cda.tar.gz
guix-forge-2e72b4c4e1bee27b260d1a925b3c103e1e1a7cda.tar.lz
guix-forge-2e72b4c4e1bee27b260d1a925b3c103e1e1a7cda.zip
forge: Introduce ci-jobs-trigger field.
Allow explicitly specifying the CI jobs trigger mechanism. This will enable us to later introduce the webhook trigger mechanism. * forge/forge.scm: Export forge-project-configuration-ci-jobs-trigger. (<forge-project-configuration>)[ci-jobs-trigger]: New field. (forge-activation): Use the ci-jobs-trigger field to decide whether to install the post receive hook. (forge-service-type): Use the ci-jobs-trigger field to decide whether to set up a cron job.
-rw-r--r--forge/forge.scm31
1 files changed, 21 insertions, 10 deletions
diff --git a/forge/forge.scm b/forge/forge.scm
index b182c6d..9a617f1 100644
--- a/forge/forge.scm
+++ b/forge/forge.scm
@@ -43,6 +43,7 @@
forge-project-configuration-repository-branch
forge-project-configuration-website-directory
forge-project-configuration-ci-jobs
+ forge-project-configuration-ci-jobs-trigger
forge-derivation-job
forge-derivation-job-name
forge-derivation-job-run
@@ -64,7 +65,15 @@
(website-directory forge-project-configuration-website-directory
(default #f))
(ci-jobs forge-project-configuration-ci-jobs
- (default '())))
+ (default '()))
+ (ci-jobs-trigger forge-project-configuration-ci-jobs-trigger ; one of 'post-receive-hook, 'cron
+ (default (cond
+ ;; 'post-receive-hook for local repositories
+ ((string-prefix? "/" (forge-project-configuration-repository this-record))
+ 'post-receive-hook)
+ ;; 'cron for remote repositories
+ (else 'cron)))
+ (thunked)))
(define-record-type* <forge-derivation-job>
forge-derivation-job make-forge-derivation-job
@@ -129,7 +138,8 @@ PROJECT-NAME."
(ci-jobs-trigger-script
(forge-project-configuration-name project)
(map forge-laminar-job-name
- (forge-project-configuration-laminar-jobs project config)))))
+ (forge-project-configuration-laminar-jobs project config)))
+ (forge-project-configuration-ci-jobs-trigger project)))
(forge-configuration-projects config))))
#~(begin
(use-modules (rnrs io ports)
@@ -143,23 +153,24 @@ PROJECT-NAME."
#:directories? #t))
(for-each (match-lambda
- ((username repository description website-directory ci-jobs-trigger)
+ ((username repository description website-directory ci-jobs-trigger ci-jobs-trigger-type)
;; For local repositories only
(when (string-prefix? "/" repository)
;; Set description.
(when description
(call-with-output-file (string-append repository "/description")
(cut put-string <> description)))
- ;; Install post receive hook.
- (let ((hook-link (string-append repository "/hooks/post-receive")))
- (when (file-exists? hook-link)
- (delete-file hook-link))
- (symlink ci-jobs-trigger hook-link))
;; Set ownership of repository files.
(for-each (lambda (file)
(let ((user (getpw username)))
(chown file (passwd:uid user) (passwd:gid user))))
(append (find-regular-files repository))))
+ ;; Install post receive hook.
+ (when (eq? ci-jobs-trigger-type 'post-receive-hook)
+ (let ((hook-link (string-append repository "/hooks/post-receive")))
+ (when (file-exists? hook-link)
+ (delete-file hook-link))
+ (symlink ci-jobs-trigger hook-link)))
;; Set ownership of website directory.
(when website-directory
(let ((user (getpw "laminar")))
@@ -246,8 +257,8 @@ derivation to run."
(service-extension mcron-service-type
(lambda (config)
(filter-map (lambda (project)
- (and (not (string-prefix?
- "/" (forge-project-configuration-repository project)))
+ (and (eq? (forge-project-configuration-ci-jobs-trigger project)
+ 'cron)
#~(job '(next-day)
#$(ci-jobs-trigger-script
(forge-project-configuration-name project)