This document contains instructions and best practices for developing against terraform-provider-hivelocity
.
NOTE: This project is still in Alpha, development best practices are still being refined
- We assume you are developing on OSX. This document will be updated to support Microsoft and Linux distros in the future.
- We assume you are working against our local development version of the core api. If you are not a Hivelocity employee, replace
http://localhost:5065
withhttps://core.hivelocity.net
. Be aware you will be charged when usingcore.hivelocity.net
. If you'd like to improve the provider without worrying about being charged, please open an issue and leave us an email address to contact you at. - You are familiar with the basics of using Terraform to create custom API calls: https://learn.hashicorp.com/tutorials/terraform/provider-use?in=terraform/providers
- You are familiar with the best practices for extending Terraform: https://www.terraform.io/docs/extend/best-practices/index.html
You may set HIVELOCITY_API_URL
to http://localhost:5065/api/v2
for development.
You may set HIVELOCITY_API_KEY
if you'd like.
The provider uses swagger-codegen to auto-generate sources for the API's client. A copy of Hivelocity's API swagger file is kept in this repository for use during the build process.
To generate the go client sources:
$ make client
If API endpoints have been added to the core, you will want to update the API swagger file and rebuild the go client. Bear in mind that the updated swagger needs to be checked into the repository.
To fetch an updated version of the swagger file and generate the client:
$ make swagger
$ make client
The swagger file will be fetched from the URL set on HIVELOCITY_API_URL environment variable.
The documentation for the Hashicorp registry is auto-generated on build-time and placed into the docs folder. It's based on the examples and descriptions of fields present on the provider's source code.
To update the local version of the docs:
$ make docs
Remember to always run this command after making changes to the examples or the provider sources, then commit the changes to the repository.
Whenever you update the project run the following cmd to add the changes to your Terraform plugins:
$ make
It is recommend you set the environment variable export TF_LOG=DEBUG
so that you can see and debug API calls while developing new functionality.
All data sources should be added to the examples/data-sources/
folder for development.
Once you have updated the example, you can test your new data source from the root of the repo:
# terraform init && terraform apply
$ EXAMPLE=examples/data-sources/<data-source> make example_apply
All resources should be added to the examples/resources/
folder for development.
Once you have updated the example, you can test your new data source from the root of the repo:
To Create/Update:
# terraform init && terraform apply
$ EXAMPLE=examples/resources/<resource> make example_apply
To Delete:
# terraform init && terraform destroy
$ EXAMPLE=examples/resources/<resource> make example_destroy
We will mostly acceptance test the provider. So you should not run them all unless you want to create tons of resources. If you make a change, when you are satisfied with the results, run the one covering whatever you changed.
NOTE: The acceptance test run will create real resources, and potentially charge you if you are developing against the prod API core.hivelocity.net
.
Please open an issue and share your email address if you would like to run tests without being charged.
$ make testacc TESTARGS='-run=TestAccHivelocityVlan_basic'
To run the full suite of acceptance tests:
$ make testacc
To run the suite of unit tests:
$ make test
Once you've built the plugin binary (see Developing the provider above), it can be incorporated within your Terraform environment using the -plugin-dir
option. Subsequent runs of Terraform will then use the plugin from your development environment.
$ terraform init -plugin-dir ~/.terraform.d/plugins/
If you need to provide a compiled version of the provider under development for usage in another platform, it's going to be necessary to cross-compile the project. To check all available platforms you can use the command go tool dist list
.
For example, if you're on Linux and you need to build a binary to be used in MacOS:
$ GOOS=darwin GOARCH=amd64 go build
The output file is going to be generated in the in the local directory: terraform-provider-hivelocity
.
To use this version, place the file in the target machine in the following path:
~/.terraform.d/plugins/registry.terraform.io/hivelocity/hivelocity/0.1.0/darwin_amd64/terraform-provider-hivelocity
.
Then run terraform init
command to import the updated version:
$ terraform init -plugin-dir ~/.terraform.d/plugins/