This repository contains utilities for managing the Linkerd development environment, especially a devcontainer. It also provides a foundation of reusable tools for CI (in GitHub Actions).
This repository is NOT intended to be used typical Linkerd development. This repository includes submodules only for the purpose of validating and automating dev tooling changes.
The devcontainer image provides all of the tools needed for interactive
development. Images are tagged as ghcr.io/linkerd/dev:vNN and is expected to
be set in a .devcontainer.json file. For example:
Several containers and setup actions are provided to configure GitHub Actions workflows.
This repository also includes additional tools in [bin/]. These scripts capture
some common build and testing tasks. Most of these scripts are implemented with
just. Just is a tool for writing build and test
'recipes'. These recipes may be invoked in the course of development or from
- just-dev lints for Devcontainer configuration and GitHub Actions workflows
- just-cargo helpers for running cargo, especially in CI
- just-k3d helpers for interacting with k3d clusters used for testing
- just-md lints markdown in a repository
- just-sh lints shell scripts in a respository.
When using just-k3d to create k3d clusters, the K3S_CHANNEL environment
variable controls the version of Kubernetes used in k3d. This value must
correspond to a channel in ./k3s-images.json, which is
stored statically in the tools and devcontainer images. This prevents the k3s
version from varying dynamically without updating the dev image.
This file is generated by running just sync-k3s-images in this repo.
The linkerd/dev/actions/setup-tools action unpacks the tools container so
that its binaries and configuration is available to subsequent steps in the job.
jobs:
lint:
runs-on: ubuntu-latest
steps:
- uses: linkerd/dev/actions/setup-tools@v43
- uses: actions/checkout@v3
- run: just-sh lint
- run: just-dev lint-actions
- run: just-dev check-action-imagesThe go container provides a Go toolchain (linters and other Go tooling are
included with the Tools image). The container can be used as a base image when
building via docker.
jobs:
test:
runs-on: ubuntu-latest
container: ghcr.io/linkerd/dev:v43-go
steps:
- uses: actions/checkout@v3
- run: go mod download
- run: go test ./...The linkerd/dev/actions/setup-go action configures the job to use the
default go version.
Linting and testing tooling must be setup via linkerd/dev/actions/setup-tools.
jobs:
test:
runs-on: ubuntu-latest
strategy:
matrix:
k8s:
- v1.21
- v1.26
steps:
# Install just* tooling and Go linters
- uses: linkerd/dev/actions/setup-tools@v43
# Configure the default Go toolchain
- uses: linkerd/dev/actions/setup-go@v43
- uses: actions/checkout@v3
- run: just-k3d K3S_CHANNEL=${{ matrix.k8s }} create
- run: go mod download
- run: go test ./...The rust container provides a Rust toolchain and associated utilities needed
to build and test Rust code. The rust-musl container provides the same
toolchain, but with the musl target installed with cross-compilation support
for arm64.
These containers can be used in a workflow like so:
jobs:
test:
runs-on: ubuntu-latest
container: ghcr.io/linkerd/dev:v43-rust
steps:
- uses: actions/checkout@v3
- run: just-cargo fetch
- run: just-cargo test-build
- run: just-cargo testOr, to build a static binary:
jobs:
test:
runs-on: ubuntu-latest
container: ghcr.io/linkerd/dev:v43-rust-musl
steps:
- uses: actions/checkout@v3
- run: just-cargo fetch
- run: just-cargo buildBuild failures are automatically reported as annotations in the GitHub UI.
The above example is fine when we're just building software, but when we want to start networked services in Docker (namely, k3d clusters), the containerized approach no longer works.
jobs:
test:
runs-on: ubuntu-latest
strategy:
matrix:
k8s:
- v1.21
- v1.25
env:
K3S_CHANNEL: ${{ matrix.k8s }}
steps:
# Install just* tooling
- uses: linkerd/dev/actions/setup-tools@v43
# Configure the default Rust toolchain
- uses: linkerd/dev/actions/setup-rust@v43
- run: just-k3d create
- run: just-cargo fetch
- run: just-cargo test-build
- run: just-cargo testBuild a single target (e.g. while editing the Dockerfile):
:; just targets=rust buildUpdate k3s images for all channels:
:; just sync-k3s-imagesPush all images:
:; just push=true version=vNN build
{ "name": "linkerd-dev", "image": "ghcr.io/linkerd/dev:v43", "extensions": [ "DavidAnson.vscode-markdownlint", "golang.go", "kokakiwi.vscode-just", "ms-kubernetes-tools.vscode-kubernetes-tools", "NathanRidley.autotrim", "rust-lang.rust-analyzer", "samverschueren.final-newline", "tamasfe.even-better-toml", "zxh404.vscode-proto3" ], "settings": { "go.lintTool": "golangci-lint" }, "runArgs": [ "--init", // Limit container memory usage. "--memory=12g", "--memory-swap=12g", // Use the host network so we can access k3d, etc. "--net=host" ], "overrideCommand": false, "remoteUser": "code", "mounts": [ { "source": "/var/run/docker.sock", "target": "/var/run/docker-host.sock", "type": "bind" }, { "source": "${localEnv:HOME}/.docker", "target": "/home/code/.docker", "type": "bind" } ] }