This Terraform provider implements (parts of) the qbee API, in order to facilitate configuration of a qbee account using Terraform.
For documentation on how to use this provider, see the provider documentation at the Terraform Registry.
If you wish to work on the provider, you'll first need Go installed on your machine (see Requirements above).
To compile the provider, run go install
. This will build the provider and put the provider binary in the $GOPATH/bin
directory.
To generate or update documentation, run go generate
.
- Terraform >= 1.0
- Go >= 1.22
- Goreleaser >= 1.20
- Clone the repository
- Enter the repository directory
- Build the provider using the Go
install
command:
go install
This provider uses Go modules. Please see the Go documentation for the most up to date information about using Go modules.
To add a new dependency github.com/author/dependency
to your Terraform provider:
go get github.com/author/dependency
go mod tidy
Then commit the changes to go.mod
and go.sum
.
In order to run the full suite of Acceptance tests, run make testacc
.
Note: Acceptance tests create real resources. They are dependent on valid qbee credentials being configured in the environment (QBEE_USERNAME and QBEE_PASSWORD).
make testacc
If you want more control over what's run and output, you can do something like:
TF_LOG=INFO TF_ACC=1 go test -count=1 -run='TestAccTagFiledistributionGroupResource' -v ./internal/provider
Where:
TF_LOG
is the log level for TerraformTF_ACC
is the flag to run acceptance testsgo test
is the command to run the tests-count=1
is the flag to run the test only once-run='TestAccTagFiledistributionGroupResource'
is the flag to run only the test with the given name
You can leave out the -run
flag to run all tests.
If you wish to use the provider locally, you can build it and place it in the correct directory.
# From the directory of terraform-provider-qbee
goreleaser build --single-target --clean
After this, the binary we built will be in ./dist/terraform-provider-qbee_OS_ARCH. Copy that to the terraform project where you want to use it:
# From the root of your terraform project (where your *.tf files are stored):
GOOS=$(go env GOOS)
GOARCH=$(go env GOARCH)
TARGET_DIR=".terraform/plugins/qbee.io/terraform/$VERSION/${GOOS}_${GOARCH}"
mkdir -p "$TARGET_DIR"
cp <dist> "$TARGET_DIR"
After that, initialize the terraform project with terraform init -plugin-dir=.terraform/plugins
_This repository is built on the Terraform Plugin Framework template.