Before You Start¶
Argo Rollouts is written in Golang. If you do not have a good grounding in Go, try out the tutorial.
Argo Rollout additionally uses
golangci-lint to lint the project.
Run the following commands to install them:
# macOS brew install golangci-lint # linux go get -u github.com/golangci/golangci-lint/cmd/golangci-lint
Brew users can quickly install the lot:
brew install go kubectl kustomize
Set up environment variables (e.g. is
export GOPATH=~/go export PATH=$PATH:$GOPATH/bin
Checkout the code:
go get -u github.com/argoproj/argo-rollouts cd ~/go/src/github.com/argoproj/argo-rollouts
Run the following command to download all the dependencies:
go mod download
go.mod is used, so the
go build/test commands automatically install the needed dependencies
make controller command will build the controller.
make codegen- Runs the code generator that creates the informers, client, lister, and deepcopies from the types.go and modifies the open-api spec. This command fails if the user has not run
go mod downloadto download all the dependencies of the project.
Running Unit Tests¶
To run unit tests:
Running E2E tests¶
The end-to-end tests need to run against a kubernetes cluster with the Argo Rollouts controller running. The rollout controller can be started with the command:
Then run the e2e tests:
- You can run the tests using a different kubeconfig by setting the
KUBECONFIG=~/.kube/minikube make start-e2e KUBECONFIG=~/.kube/minikube make test-e2e
- To run a specific e2e test, set the
E2E_TEST_OPTIONSenvironment variable to specify the test (or test regex):
make test-e2e E2E_TEST_OPTIONS="-testify.m ^TestRolloutRestart$"
- The e2e tests are designed to run as quickly as possible, eliminating readiness and termination
delays. However, it is often desired to artificially slow down the tests for debugging purposes,
as well as to understand what the test is doing. To delay startup and termination of pods, set the
E2E_POD_DELAYto a integer value in seconds. This environment variable is often coupled with
E2E_TEST_OPTIONSto debug and slow down a specific test.
make test-e2e E2E_POD_DELAY=10
- Increasing the timeout. The E2E tests time out waiting on conditions to be met within 60 seconds. If debugging the rollout controller, it may be useful to increase this timeout while say sitting at a debugger breakpoint:
make test-e2e E2E_WAIT_TIMEOUT=999999
- The e2e tests leverage a feature of the controller allowing the controller to be sharded with
a user-specific "instance id" label. This allows the tests to operate only on rollouts with the
specified label, and prevents any other controllers (including the system rollout controller),
from also operating on the same set of rollouts. This value can be changed (from the default of
argo-rollouts-e2e), using the
make start-e2e E2E_INSTANCE_ID=foo make test-e2e E2E_INSTANCE_ID=foo
Alternatively, the e2e tests can be run against the system controller (i.e. without an instance id):
make start-e2e E2E_INSTANCE_ID=''
It is much easier to run and debug if you run Argo Rollout in your local machine than in the Kubernetes cluster.
cd ~/go/src/github.com/argoproj/argo-rollouts go run ./cmd/rollouts-controller/main.go
Running Local Containers¶
You may need to run containers locally, so here's how:
Create login to Docker Hub, then login.
Add your username as the environment variable, e.g. to your
Build the images:
DOCKER_PUSH=true make image
Update the manifests:
Install the manifests:
kubectl -n argo-rollouts apply -f manifests/install.yaml
Upgrading Kubernetes Libraries¶
Argo Rollouts has a dependency on the kubernetes/kubernetes repo for some of the functionality that has not been
pushed into the other kubernetes repositories yet. In order to import the kubernetes/kubernetes repo, all of the
associated repos have to pinned to the correct version specified by the kubernetes/kubernetes release. The
./hack/update-k8s-dependencies.sh updates all the dependencies to the those correct versions.
Modify contents in
Preview changes in your browser by visiting http://localhost:8000 after running:
To publish changes, run: