feat(kit): Export TVL kit as a josh workspace

This creates a josh workspace called `views/kit` which exports all
dependencies needed by external users of the TVL kit.

The intention of this is to have a single clonable "virtual repo"
which provides everything needed to run a system like TVL, but without
the projects that we develop *in* TVL.

Right now this is limited to the basic Nix code (readTree, pipeline
generation) and things required for Gerrit integration.

The workspace maps depot paths into slightly different (simpler)
locations inside the exported view, to avoid a nested, mostly empty
structure.

Note: This is not an "external API" or some such of depot, it is
simply a convenience for exporting some of our tooling.

Change-Id: Ied24aaef117fc2e0c188ec742ae7cd993a5babd3
Reviewed-on: https://cl.tvl.fyi/c/depot/+/4991
Tested-by: BuildkiteCI
Reviewed-by: sterni <sternenseemann@systemli.org>
This commit is contained in:
Vincent Ambo 2022-01-18 18:33:05 +03:00 committed by tazjin
parent 14d1ba8311
commit e1146601c1
5 changed files with 57 additions and 0 deletions

2
views/.skip-subtree Normal file
View file

@ -0,0 +1,2 @@
//views is not part of the depot build tree, see the README for more
information.

6
views/README.md Normal file
View file

@ -0,0 +1,6 @@
depot views
===========
This folder contains external views of depot content, defined using
josh workspaces. See the individual views for a description of their
content and usage information.

22
views/kit/README.md Normal file
View file

@ -0,0 +1,22 @@
The TVL Kit
===========
This folder contains a publicly available version of the core TVL
tooling, currently comprising of:
* `buildkite`: TVL tooling for dynamically generating Buildkite
pipelines with Nix.
* `buildGo`: Nix-based build system for Go.
* `readTree`: Nix library to dynamically compute attribute trees
corresponding to the physical layout of a repository.
* `besadii`: Configurable Gerrit/Buildkite integration hook.
It can be accessed via git by cloning it as such:
git clone https://code.tvl.fyi/depot.git:workspace=views/kit.git tvl-kit
If you are looking at this within the TVL depot, you can see the
[josh][] configuration in `workspace.josh`. You will find the projects
at slightly different paths within the depot.
[josh]: https://github.com/josh-project/josh/

19
views/kit/default.nix Normal file
View file

@ -0,0 +1,19 @@
# Externally importable TVL depot stack. This is intended to be called
# with a supplied package set, otherwise the package set currently in
# use by the TVL depot will be used.
#
# For now, readTree is not used inside of this configuration to keep
# it simple. Adding it may be useful if we set up test scaffolding
# around the exported workspace.
{ pkgs ? import ./nixpkgs { depotOverlays = false; }, ... }:
pkgs.lib.fix(self: {
buildGo = import ./buildGo { inherit pkgs; };
buildkite = import ./buildkite { inherit pkgs; };
readTree = import ./readTree { };
besadii = import ./besadii {
depot.nix.buildGo = self.buildGo;
};
})

8
views/kit/workspace.josh Normal file
View file

@ -0,0 +1,8 @@
::LICENSE
besadii = :/ops/besadii
:/nix:[
::buildGo/
::buildkite/
::readTree/
]
nixpkgs = :/third_party/nixpkgs