This is not a lot of test coverage around the resources themselves. This is due to the cost of running the tests. However, libnuke is extensively tested for functionality to ensure a smooth experience.
Generally speaking, the tests are split into two categories:
- Tool Testing
- Resource Testing
Furthermore, for resource testing, these are broken down into two additional categories:
- Mock Tests
- Integration Tests
These are unit tests written against non resource focused code inside the pkg/
directory.
These are unit tests written against the resources in the resources/
directory.
These are tests where the AWS API calls are mocked out. This is done to ensure that the code is working as expected. Currently, there are only two services mocked out for testing, IAM and CloudFormation.
To add another service to be mocked out, you will need to do the following:
- Identify the service in the AWS SDK for Go
- Create a new file in the
resources/
directory called<service>_mock_test.go
- Add the following code to the file: (replace
<service>
with actual service name)//go:generate ../mocks/generate_mocks.sh <service> <service>iface package resources // Note: empty on purpose, this file exist purely to generate mocks for the <service> service
- Run
make generate
to generate the mocks - Add tests to the
resources/<service>_mock_test.go
file. - Run
make test
to ensure the tests pass - Submit a PR with the changes
These are tests where the AWS API calls are called directly and tested against a live AWS account. These tests are
behind a build flag (-tags=integration
), so they are not run by default. To run these tests, you will need to run the following:
make test-integration
To add another integration test, you will need to do the following:
- Create a new file in the
resources/
directory called<resource>_test.go
- Add the following code to the file: (replace
<resource>
with actual resource name)//go:build integration package resources import ( "testing" "github.com/aws/aws-sdk-go/aws/session" "github.com/aws/aws-sdk-go/service/<resource>" ) func Test_ExampleResource_Remove(t *testing.T) { // 1. write code to create resource in AWS using golang sdk // 2. stub the resource struct out that is defined in <resource>.go file // 3. call the Remove() function // 4. assert that the resource was removed }
- Run
make test-integration
to ensure the tests pass - Submit a PR with the changes