Skip to content

Commit

Permalink
📖 Document example VSCode envtest integration
Browse files Browse the repository at this point in the history
* Add 'setup-envtest' make target to setup envtest on demand.
* Document how to configure VSCode.
  • Loading branch information
dlipovetsky committed Mar 1, 2023
1 parent 1a5c13c commit 4888af5
Show file tree
Hide file tree
Showing 6 changed files with 72 additions and 0 deletions.
4 changes: 4 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -731,6 +731,10 @@ ARTIFACTS ?= ${ROOT_DIR}/_artifacts

KUBEBUILDER_ASSETS ?= $(shell $(SETUP_ENVTEST) use --use-env -p path $(KUBEBUILDER_ENVTEST_KUBERNETES_VERSION))

.PHONY: setup-envtest
setup-envtest: $(SETUP_ENVTEST) ## Set up envtest (download kubebuilder assets)
@echo KUBEBUILDER_ASSETS=$(KUBEBUILDER_ASSETS)

.PHONY: test
test: $(SETUP_ENVTEST) ## Run unit and integration tests
KUBEBUILDER_ASSETS="$(KUBEBUILDER_ASSETS)" go test ./... $(TEST_ARGS)
Expand Down
3 changes: 3 additions & 0 deletions dev/vscode-example-configuration/settings.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
"go.testEnvFile": "${workspaceFolder}/.vscode/test.env"
}
32 changes: 32 additions & 0 deletions dev/vscode-example-configuration/tasks.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
{
// See https://go.microsoft.com/fwlink/?LinkId=733558
// for the documentation about the tasks.json format
"version": "2.0.0",
"tasks": [
{
"type": "shell",
"label": "sigs.k8s.io/cluster-api: Prepare vscode to run envtest-based tests",
"detail": "Install envtest and configure the vscode-go test environment.",
"group": {
"kind": "test",
"isDefault": true
},
"command": [
"echo $(make setup-envtest) > ${workspaceFolder}/.vscode/test.env",
],
"presentation": {
"echo": true,
"reveal": "silent",
"focus": true,
"panel": "shared",
"showReuseMessage": true,
"clear": false
},
"runOptions": {
"runOn": "folderOpen",
"instanceLimit": 1,
},
"promptOnClose": true,
}
]
}
Empty file.
5 changes: 5 additions & 0 deletions docs/book/src/developer/repository-layout.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ cluster-api
└───config
└───controllers
└───controlplane
└───dev
└───docs
└───errors
└───exp
Expand Down Expand Up @@ -115,6 +116,10 @@ This folder has scripts used for building, testing and developer workflow.

This folder consists of CI scripts related to setup, build and e2e tests. These are mostly called by CI jobs.

[~/dev](https://github.com/kubernetes-sigs/cluster-api/tree/main/dev)

This folder has example configuration for integrating Cluster API development with tools like IDEs.

### Util, Feature and Errors

[~/util](https://github.com/kubernetes-sigs/cluster-api/tree/main/util)
Expand Down
28 changes: 28 additions & 0 deletions docs/book/src/developer/testing.md
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,8 @@ but in this case the distinctive value of the two layers of testing is determine

Run `make test` to execute all unit and integration tests.

Integration tests use the [envtest](https://github.com/kubernetes-sigs/controller-runtime/blob/master/pkg/envtest/doc.go) test framework. The tests need to know the location of the executables called by the framework. The `make test` target installs these executables, and passes this location to the tests as an environment variable.

<aside class="note">

<h1>Tips</h1>
Expand All @@ -113,6 +115,30 @@ To debug testenv unit tests it is possible to use:

</aside>

### Test execution via IDE

Your IDE needs to know the location of the executables called by the framework, so that it can pass the location to the tests as an environment variable.

<aside class="note warning">

<h1>Warning</h1>

If you see this error when running a test in your IDE, the test uses the envtest framework, and probably does not know the location of the envtest executables.

```console
E0210 16:11:04.222471 132945 server.go:329] controller-runtime/test-env "msg"="unable to start the controlplane" "error"="fork/exec /usr/local/kubebuilder/bin/etcd: no such file or directory" "tries"=0
```

</aside>

#### VSCode

The `dev/vscode-example-configuration` directory in the repository contains an example configuration that integrates VSCode with the envtest framework.

To use the example configuration, copy the files to the `.vscode` directory in the repository, and restart VSCode.

The configuration works as follows: Whenever the project is opened in VSCode, a VSCode task runs that installs the executables, and writes the location to a file. A setting tells [vscode-go] to initialize the environment from this file.

## End-to-end tests

The end-to-end tests are meant to verify the proper functioning of a Cluster API management cluster
Expand Down Expand Up @@ -536,3 +562,5 @@ In Cluster API Unit and integration test MUST use [go test].
[envtest]: https://github.com/kubernetes-sigs/controller-runtime/tree/master/pkg/envtest
[fakeclient]: https://github.com/kubernetes-sigs/controller-runtime/tree/master/pkg/client/fake
[test/helpers]: https://github.com/kubernetes-sigs/cluster-api/tree/main/test/helpers

[vscode-go]: https://marketplace.visualstudio.com/items?itemName=golang.Go

0 comments on commit 4888af5

Please sign in to comment.