about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ci-builds.nix119
-rw-r--r--default.nix23
-rw-r--r--ops/pipelines/depot.nix2
3 files changed, 22 insertions, 122 deletions
diff --git a/ci-builds.nix b/ci-builds.nix
deleted file mode 100644
index 78aadf1d61..0000000000
--- a/ci-builds.nix
+++ /dev/null
@@ -1,119 +0,0 @@
-# This file defines the derivations that should be built by CI.
-#
-# The "categories" (i.e. attributes) below exist because we run out of
-# space on Sourcehut otherwise.
-{ depot, lib, ... }:
-
-let
-  inherit (builtins) attrNames filter foldl' getAttr substring;
-
-  # attach a nix expression to a drv so we can “build” it
-  # TODO(Profpatsch): instead of failing evaluation if a test fails,
-  # we can put the expression of the test failure into $out
-  # and continue with the other CI derivations.
-  drvify = name: exp: depot.nix.emptyDerivation {
-    inherit name;
-    owo = lib.generators.toPretty {} exp;
-  };
-
-  systemFor = configuration: (depot.third_party.nixos {
-    inherit configuration;
-  }).system;
-
-in lib.fix (self: {
-  __apprehendEvaluators = throw ''
-    Do not evaluate this attribute set directly. It exists only to group builds
-    for CI runs of different "project groups".
-
-    To use the depot, always start from the top-level attribute tree instead.
-  '';
-
-  # Names of all evaluatable attributes in here. This list will be
-  # used to trigger builds for each key.
-  __evaluatable = filter (key: (substring 0 2 key) != "__") (attrNames self);
-
-  # Combined list of all the targets, used for building everything locally.
-  __allTargets =
-    (with depot.nix.yants; list drv)
-    (foldl' (x: y: x ++ y) [] (map (k: getAttr k self) self.__evaluatable));
-
-  fun = with depot.fun; [
-    amsterdump
-    clbot
-    gemma
-    paroxysm
-    paroxysm.docker
-    quinistry
-    watchblob
-    wcl
-  ];
-
-  ops = with depot.ops; [
-    depot.ops."posix_mq.rs"
-    besadii
-    journaldriver
-    kontemplate
-    mq_cli
-    (systemFor nixos.whitby)
-  ];
-
-  third_party = with depot.third_party; [
-    apereo-cas
-    bufbuild
-    cgit
-    git
-    grpc
-    loxy
-    nix
-    nix.test-vm
-    openldap
-    rapidcheck
-  ];
-
-  gerrit = with depot.third_party.gerrit_plugins; [
-    depot.third_party.gerrit
-    checks
-    owners
-  ];
-
-  lisp = with depot.lisp; [
-    dns
-    klatre
-  ];
-
-  various = with depot; [
-    nix.buildLisp.example
-    nix.yants.tests
-    tools.cheddar
-    tools.nsfv-setup
-    web.cgit-taz
-    web.todolist
-    web.tvl
-    web.panettone
-    (drvify "getBins-tests" nix.getBins.tests)
-  ]
-  ++ nix.runExecline.tests
-  ;
-
-  # Haskell packages we've patched locally
-  haskellPackages = with depot.third_party.haskellPackages; [
-    generic-arbitrary
-    hgeometry
-    hgeometry-combinatorial
-    vinyl
-    comonad-extras
-
-    # TODO(grfn): Disabled because of build errors with recent nixpkgs
-    # depot.third_party.haskell-language-server.ghc883
-  ];
-
-  # User-specific build targets
-  tazjin = with depot.users.tazjin; [
-    blog.rendered
-    emacs
-    finito
-    homepage
-    (systemFor nixos.camden)
-    (systemFor nixos.frog)
-  ];
-})
diff --git a/default.nix b/default.nix
index 13a9f5d588..b0b5399c4b 100644
--- a/default.nix
+++ b/default.nix
@@ -39,6 +39,22 @@ let
     users         = readTree ./users;
     web           = readTree ./web;
   };
+
+  # To determine build targets, we walk through the depot tree and
+  # fetch attributes that were imported by readTree and are buildable.
+  #
+  # Any build target that contains `meta.ci = false` will be skipped.
+
+  # Is this tree node eligible for build inclusion?
+  eligible = node: (node ? outPath) && (node.meta.ci or true);
+
+  # Walk the tree starting with 'node', recursively extending the list
+  # of build targets with anything that looks buildable.
+  gather = node:
+    if node ? __readTree then
+      (if eligible node then [node] else []) ++
+      concatMap gather (attrValues node)
+    else [];
 in fix(self: {
   config = config self;
 
@@ -55,8 +71,11 @@ in fix(self: {
   # (e.g. NixOS module inclusions)
   depotPath = ./.;
 
-  # Load CI builds in a way that can be injected into programs like besadii.
-  ciBuilds = import ./ci-builds.nix self.config;
+  # List of all buildable targets, for CI purposes.
+  #
+  # Note: This *must* be a nested attribute, otherwise we will get
+  # infinite recursion and everything blows up.
+  ci.targets = gather self;
 }
 
 # Add local packages as structured by readTree
diff --git a/ops/pipelines/depot.nix b/ops/pipelines/depot.nix
index ad5a3faabe..2e99bf8d13 100644
--- a/ops/pipelines/depot.nix
+++ b/ops/pipelines/depot.nix
@@ -14,7 +14,7 @@ let
   # documented on https://buildkite.com/docs/pipelines/defining-steps
   pipeline.steps = [
     {
-      command = "nix-build -A ciBuilds.__allTargets --show-trace";
+      command = "nix-build -A ci.targets --show-trace";
       label = ":duck:";
     }
     {