Skip to content

Commit

Permalink
just: make cli variant configurable
Browse files Browse the repository at this point in the history
Introduces a new parameter for some just targets that allows overriding
the nix rule used to build the cli.

The dev variant stays the default, while the release variant is used for
e2e testing.
  • Loading branch information
burgerdev committed Feb 21, 2024
1 parent bb3c59f commit 30a3af1
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 11 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/e2e_simple.yml
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ jobs:
just get-credentials
- name: Build, deploy, nunki generate, nunki set, nunki verify
run: |
just default simple
just default simple cli-release
- name: Summary
run: |
cat ./workspace/just.namespace | tee -a "${GITHUB_STEP_SUMMARY}"
Expand Down
21 changes: 11 additions & 10 deletions justfile
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
# Undeploy, rebuild, deploy.
default target=default_deploy_target: undeploy coordinator initializer openssl port-forwarder (deploy target) set verify (wait-for-workload target)
default target=default_deploy_target cli=default_cli: undeploy coordinator initializer openssl port-forwarder (generate target cli) apply set verify (wait-for-workload target)

# Build the coordinator, containerize and push it.
coordinator:
Expand All @@ -17,14 +17,15 @@ port-forwarder:
initializer:
nix run .#containers.push-initializer -- "$container_registry/nunki/initializer"

default_cli := "nunki.cli"
default_deploy_target := "simple"
workspace_dir := "workspace"

# Generate policies, apply Kubernetes manifests.
deploy target=default_deploy_target: (generate target) apply
deploy target=default_deploy_target cli=default_cli: (generate target cli) apply

# Generate policies, update manifest.
generate target=default_deploy_target:
generate target=default_deploy_target cli=default_cli:
#!/usr/bin/env bash
set -euo pipefail
mkdir -p ./{{ workspace_dir }}
Expand All @@ -37,7 +38,7 @@ generate target=default_deploy_target:
nix run .#kypatch namespace -- ./{{ workspace_dir }}/deployment \
--replace edg-default {{ target }}${namespace_suffix-}
t=$(date +%s)
nix run .#nunki.cli -- generate \
nix run .#{{ cli }} -- generate \
-m ./{{ workspace_dir }}/manifest.json \
-p ./{{ workspace_dir }}/rules.rego \
-s ./{{ workspace_dir }}/genpolicy-msft.json \
Expand Down Expand Up @@ -69,7 +70,7 @@ create:
nix run .#scripts.create-coco-aks -- --name="$azure_resource_group"

# Set the manifest at the coordinator.
set:
set cli=default_cli:
#!/usr/bin/env bash
set -euo pipefail
ns=$(cat ./{{ workspace_dir }}/just.namespace)
Expand All @@ -81,7 +82,7 @@ set:
nix run .#scripts.wait-for-port-listen -- 1313
policy=$(<./{{ workspace_dir }}/just.coordinator-policy-hash)
t=$(date +%s)
nix run .#nunki.cli -- set \
nix run .#{{ cli }} -- set \
-m ./{{ workspace_dir }}/manifest.json \
-c localhost:1313 \
--coordinator-policy-hash "${policy}" \
Expand All @@ -91,7 +92,7 @@ set:
echo "set $duration" >> ./{{ workspace_dir }}/just.perf
# Verify the Coordinator.
verify:
verify cli=default_cli:
#!/usr/bin/env bash
set -euo pipefail
rm -rf ./{{ workspace_dir }}/verify
Expand All @@ -102,7 +103,7 @@ verify:
trap "kill $PID" EXIT
nix run .#scripts.wait-for-port-listen -- 1314
t=$(date +%s)
nix run .#nunki.cli -- verify \
nix run .#{{ cli }} -- verify \
-c localhost:1314 \
-o ./{{ workspace_dir }}/verify
duration=$(( $(date +%s) - $t ))
Expand Down Expand Up @@ -164,11 +165,11 @@ fmt:
lint:
nix run .#scripts.golangci-lint -- run

demodir: undeploy coordinator initializer
demodir cli=default_cli: undeploy coordinator initializer
#!/usr/bin/env bash
d=$(mktemp -d)
echo "Creating demo directory at ${d}"
nix build .#nunki.cli
nix build .#{{ cli }}
cp ./result-cli/bin/nunki "${d}/nunki"
cp -R ./deployments/emojivoto "${d}/deployment"
nix run .#scripts.patch-nunki-image-hashes -- "${d}/deployment"
Expand Down

0 comments on commit 30a3af1

Please sign in to comment.