Categorygithub.com/packethost/terraform-provider-packet
repositorypackage
3.2.1+incompatible
Repository: https://github.com/packethost/terraform-provider-packet.git
Documentation: pkg.go.dev

# Packages

No description provided by the author

# README

Equinix Metal Terraform Provider

GitHub release Go Report Card

Slack Twitter Follow

Packet is now Equinix Metal!

This repository is Maintained meaning that this software is supported by Equinix Metal and its community - available to use in production environments.

Using the provider

The Equinix Metal provider will be installed on terraform init of a template using any of the packet_* resources.

See https://registry.terraform.io/providers/packethost/packet/latest/docs for documentation on the resources included in this provider.

Requirements

  • Terraform 0.12+ (for v3.0.0 of this provider and newer)
  • Go 1.13 (to build the provider plugin)

Building the provider

Clone repository to: $GOPATH/src/github.com/packethost/terraform-provider-packet

mkdir -p $GOPATH/src/github.com/packethost; cd $GOPATH/src/github.com/packethost
git clone [email protected]:packethost/terraform-provider-packet

Enter the provider directory and build the provider

cd $GOPATH/src/github.com/packethost/terraform-provider-packet
make build

Developing the provider

If you wish to work on the provider, you'll first need Go installed on your machine (version 1.13+ is required). You'll also need to correctly setup a GOPATH, as well as adding $GOPATH/bin to your $PATH.

To compile the provider, run make build. This will build the provider and put the provider binary in the $GOPATH/bin directory.

$ make bin
...
$ $GOPATH/bin/terraform-provider-packet
...

Testing provider code

We have mostly acceptance tests in the provider. There's no point for you to run them all, but you should run the one covering the functionality which you change. The acceptance test run will cost you some money, so feel free to abstain. The acceptance test suite will be run for your PR during the review process.

To run an acceptance test, find the relevant test function in *_test.go (for example TestAccPacketDevice_Basic), and run it as

TF_ACC=1 go test -v -timeout=20m -run=TestAccPacketDevice_Basic

If you want to see HTTP traffic, set TF_LOG=DEBUG, i.e.

TF_LOG=DEBUG TF_ACC=1 go test -v -timeout=20m -run=TestAccPacketDevice_Basic

Testing the provider with Terraform

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 $GOPATH/bin