This document details our goals for code quality, coverage and documentation standards. At the time of this writing, these are standards that all of our code may not meet. We should always try to improve our codebase and documentation to meet them.
While we do not currently aim to adhere completely to the Kubernetes coding conventions, we aspire to adhere as closely as possible.
We aim to write clear code that is easy to read and comprehend. In particular, that goal means the following:
-
All Go code must pass the Go linter checks
- We have these checks integrated into our CI system
-
All Go code should pass
go vet
- This check is integrated into our CI system
- Anyone with the Go toolchain installed on their system can run the vet checks by executing the following command on their machine:
go vet ./pkg/... ./cmd/... ./test/...
-
All Go code must be formatted with gofmt
- Anyone can run the formatter by runinng
make format
on their machine
- Anyone can run the formatter by runinng
-
Any exported symbols (
type
s,interface
s,func
s,struct
s, etc...) must have Godoc compatible comments associated with them -
Unexported symbols must be commented sufficiently to provide direction & context to a developer who didn't write the code
-
Inline code should be commented sufficiently to explain what complex code is doing. It's up to the developer and reviewers how much and what kind of documentation is necessary
-
Unit, integration or end-to-end tests should be written for all business logic
- Reviewers should take care to ensure the right, and enough testing is written for a PR
- We do not yet check code coverage in our CI system