Validation
End-to-end (e2e) tests for Kubernetes provide a mechanism to test the behaviour of the system. This is a useful indicator that the cluster is performing properly, as well as a good validation of any code changes.
For Charmed Kubernetes, these tests are encapsulated in an additional Juju charm which can be added to your cluster. Actual testing is then run through the charm’s actions.
Caution:
Your cluster will need to have at least two running worker units for the e2e
test to run properly.
Deploying the kubernetes-e2e charm
Add the charm to your cluster:
juju deploy cs:~containers/kubernetes-e2e --constraints mem=4G --channel edge
We also need to configure the charm to select the appropriate version of tests. This relates to the installed version of Kubernetes. You can check which version your cluster is set to by running:
juju config kubernetes-master channel
The output will be in the form of ‘version.number/risk’, e.g ‘1.12/stable’. You should set
the kubernetes-e2e
channel to the same value.
juju config kubernetes-e2e channel=1.12/stable
Finally we relate the charm to easyrsa
and kubernetes-master
:
juju config kubernetes-master allow-privileged=true
juju config kubernetes-worker allow-privileged=true
juju add-relation kubernetes-e2e easyrsa
juju add-relation kubernetes-e2e:kubernetes-master kubernetes-master:kube-api-endpoint
juju add-relation kubernetes-e2e:kube-control kubernetes-master:kube-control
It may take some moments for these relations to establish. Once the connections are made, the charm will update its status to “Ready to test.”
Running the default tests
The tests are configured as a Juju action. To run the default tests:
juju run-action kubernetes-e2e/0 test
The command will return with a uuid for that specific test run. See the section on Test output below for details.
Running specific tests
The complete set of Kubernetes e2e tests is more fully described in the upstream Kubernetes documentation. In some cases you may wish to omit particular groups of tests. This is possible by applying a regular expression defining the tests to omit when initiating the action.
By default, the standard tests marked [Flaky]
or [Serial]
are skipped. To
also omit the tests marked as [Slow]
, you could run:
juju run-action kubernetes-e2e/0 test skip='\[(Flaky|Slow|Serial)\]'
Note that the brackets for the regex need to be escaped as shown.
Running this command will return a uuid for that specific test run, as with the default case.
Test output
You can check on the current status of the test by running:
juju show-action-status 8f8ec748-6ca7-4bbb-86f8-f37e44ba46f9
where 8f8ec748-6ca7-4bbb-86f8-f37e44ba46f9
is the uuid of the action returned
when we initiated the test. This will return YAML output indicating the current
status, which can be either running
, completed
or failed
.
actions:
- action: test
completed at: n/a
id: 8f8ec748-6ca7-4bbb-86f8-f37e44ba46f9
status: running
unit: e2e/0
Once completed, you can see more detail on the timing by running:
juju show-action-status 8f8ec748-6ca7-4bbb-86f8-f37e44ba46f9
Which will return output similar to:
results:
junit: /home/ubuntu/8f8ec748-6ca7-4bbb-86f8-f37e44ba46f9-junit.tar.gz
log: /home/ubuntu/8f8ec748-6ca7-4bbb-86f8-f37e44ba46f9.log.tar.gz
status: completed
timing:
completed: 2018-10-06 18:33:15 +0000 UTC
enqueued: 2018-10-06 18:25:30 +0000 UTC
started: 2018-10-06 18:25:30 +0000 UTC
If the tests fail, or you want to look through the detail of each test, you can examine the detailed log.
Viewing test logs
The test logfile is stored as a file on the test instance. The filename
corresponds to the uuid of the action which created it, with a ‘.log’
extension, and it is stored in the /home/ubuntu/
directory of the machine
where the tests are running. A compressed version is also stored with the
extension .log.tar.gz
This log can be copied to your local machine for easier viewing:
juju scp kubernetes-e2e/0:4ceed33a-d96d-465a-8f31-20d63442e51b.log .
Note that the captured test logfile uses ANSI output, and is best viewed with
cat
, tail
or a similar command which can handle this type of output.
Alternatively, you can strip the ANSI parts of the output:
fn=<your log file name>
echo -ne $(cat $fn | sed 's/$/\\n/' | sed 's/\x1B\[[0-9]*\w//g')
Caution: If you are running regular tests in this way, it is advisable to remove the generated logs from the test unit. The uncompressed logs in particular can be very large and quickly fill up storage.
Upgrading the e2e tests
When an update is available, the kubernetes-e2e
charm can be upgraded with the command:
juju upgrade-charm kubernetes-e2e