-
Notifications
You must be signed in to change notification settings - Fork 79
Testing
In Garden we have always taken testing quite seriously. The whole code base had been developed in a test driven manner, which basically means that there are tons of tests. We never really measured our code coverage but we suspect it is pretty darn high. Due to the low level nature of the project and its use of linux kernel primitives some tests can only run on linux. Some of our tests are being run on both linux and windows to check cross platform compatibility. Since we are all working on Mac OS machines all our tests rely heavily on Concourse - a continuous integration system that can run both linux and windows nodes. We also like Ginkgo - a golang BDD testing framework powering all our test suites.
You can run all tests in most of the garden repostiries by executing the following command in the repo root:
scripts/test
You can think about the scripts
dir as a Makefile, each script being a target.
Note: Some scripts/test
scripts will attempt to run the tests on concourse, so make sure you have fly
- the concourse cli - installed and that you are logged onto concourse. Here is how you login in garden's concourse server
fly -t garden-ci login -c https://garden.ci.cf-app.com/
Garden has the following types of test suites:
- unit tests: these live next to the code and use fakes generated by counterfeiter
- integration tests: these usually live in the
integration
subdirectory in the repo they are tesing and involve running the actual binary with different options and configurations. There is one exception - the GQTs - the guardian integration tests. - acceptance tests: these live in their own repo and depend on a full deployment of the product they are testing. Since they are run against a given deploment, they cannot alter its configurations.
- performance tests: these live in their own repo
Given that all our test scripts are a bit different you may want to read them to fully understand their behaviour, here are a few examoles of our most imporant test scripts.
-
./scripts/test -a
: runs all tests in parallel in tmux split windows. This is how we usually run these tests to save time. However you have to have tmux installed and configured. ./scripts/test
./scripts/test
- TODO: focusing tests, untilItFails, etc
-
./script/test -a
: runs all tests in parallel in tmux split windows. -
./script/test -u
: runs all unit tests - TODO: focusing tests, untilItFails, etc
TODO: what is a flake, https://medium.com/@teddyking/the-night-is-dark-and-full-of-flakes-29c529404c3c