- GO unit testing functions MUST be prefixed with
TestUnit
enabling filtering in testing_unit.yaml - GO unit test source code file SHOULD be named after the code source file using the suffix
_unit_test.go
example.- Code source file
func_validatestruct.go
- Unit tests code file
func_validatestruct_unit_test.go
- Code source file
- Unit tests MUST be small enough so all the unit tests are run on each push and each PR update: testing_unit.yaml
- Unit test MUST run in isolation:
- No real call to a dependency API
- meaning, the service account used to run the CI pipeline need no expertanl API IAM related role
- Test double (mocks / stubs/ fakes) are not encouraged:
- prefer to use a real object
- As calling real object is not allowed in unit test (previous guideline), move these tests to small integration tests (next section)
- No real call to a dependency API
- GO integration testing functions MUST be prefixed with
TestInteg
enabling filtering in testing_integ.yaml - GO integration test source code file SHOULD be named after the code source file using the suffix
_integ_test.go
example- Code source file
meth_folderdeployment_deploy.go
- Unit tests code file
meth_folderdeployment_deploy_integ_test.go
- Code source file
- Integration tests MUST be small enough so a GO package integration tests are run on each push on the package code and each PR to master update: testing_integ.yaml
- The project hosting the integration tests MUST have a project name that contains
ram-build
avoiding resources deletion, creation driven during integration test to occur in the wrong project - To run integration tests locally set the environment variable
RAM_ITEST_PROJECT_ID
- The project hosting the integration tests MUST have a Cloud Operation Workspace hosted by itself
- The following IAM bindings MUST be set with the service account used to run integration tests:
- sandboxes folder
- folder admin
- required by: grm
- folder admin
- project hosting integration tests
- editor
- required to create, delete integration test resources
- editor
- sandboxes folder
- The project hosting the service account used to run the integration test MUST have the following API enabled:
- Cloud Resource Manager API