/terraform-provider-ovh

Terraform OVH provider

Primary LanguageGoMozilla Public License 2.0MPL-2.0

Terraform OVH Provider

Requirements

  • Terraform 0.10.x
  • Go 1.8 (to build the provider plugin)

Building The Provider

Clone repository to: $GOPATH/src/github.com/terraform-providers/terraform-provider-ovh

$ mkdir -p $GOPATH/src/github.com/terraform-providers/; cd $GOPATH/src/github.com/terraform-providers/
$ git clone git@github.com:terraform-providers/terraform-provider-ovh

Enter the provider directory and build the provider

$ cd $GOPATH/src/github.com/terraform-providers/terraform-provider-ovh
$ make build

Using the provider

Please see the documentation at terraform.io.

Or you can browse the documentation within this repo here.

Developing the Provider

If you wish to work on the provider, you'll first need Go installed on your machine (version 1.8+ 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 build
...
$ $GOPATH/bin/terraform-provider-ovh
...

Testing the Provider

In order to test the provider, you can simply run make test.

$ make test

In order to run the full suite of Acceptance tests you will need to have the following list of OVH products attached to your account:

You will also need to setup your OVH api credentials. (see documentation)

Once setup, please follow these steps to prepare an environment for running the Acceptance tests:

$ cat > ~/.ovhrc <<EOF
# setup ovh api credentials
export OVH_ENDPOINT="ovh-eu"
export OVH_APPLICATION_KEY="..."
export OVH_APPLICATION_SECRET="..."
export OVH_CONSUMER_KEY="..."

# ovh public cloud project id
export OVH_PUBLIC_CLOUD=...

# ovh vrack id
export OVH_VRACK=...

# ovh zone name
export OVH_ZONE=...

# ovh load balancer service id
export OVH_IPLB_SERVICE=loadbalancer-...

# if you have a load balancer attached to your account
# you can use its public ipv4 to use for testing the
# ip reverse feature as follows.
# otherwise, you shall order a public IP and register it within
# your ovh managed zone.
export OVH_IP_BLOCK=A.B.C.D/32
export OVH_IP=A.B.C.D
export OVH_IP_REVERSE=ipD.ip-A-B-C.eu.
EOF
$ source ~/.ovhrc

In order for all the tests to pass you can run:

$ make testacc

To filter acceptance test, you can run:

$ make testacc TESTARGS="-run TestAccPublicCloudPrivateNetwork"

To remove dangling resources, you can run:

$ make testacc TESTARGS="-sweep"