2017-06-05 16:59:08 -04:00
Terraform Provider
==================
- Website: https://www.terraform.io
- [](https://gitter.im/hashicorp-terraform/Lobby)
- Mailing list: [Google Groups ](http://groups.google.com/group/terraform-tool )
2017-08-31 11:05:07 -04:00
< img src = "https://cdn.rawgit.com/hashicorp/terraform-website/master/content/source/assets/images/logo-hashicorp.svg" width = "600px" >
2017-06-05 16:59:08 -04:00
Requirements
------------
- [Terraform ](https://www.terraform.io/downloads.html ) 0.10.x
2018-05-16 12:00:04 -04:00
- [Go ](https://golang.org/doc/install ) 1.9.1 (to build the provider plugin)
2017-06-05 16:59:08 -04:00
Building The Provider
---------------------
2018-05-02 13:33:52 -04:00
Clone repository to: `$GOPATH/src/github.com/terraform-providers/terraform-provider-docker`
2017-06-05 16:59:08 -04:00
```sh
2017-10-23 15:11:15 -04:00
$ mkdir -p $GOPATH/src/github.com/terraform-providers; cd $GOPATH/src/github.com/terraform-providers
2018-05-02 13:33:52 -04:00
$ git clone git@github.com:terraform-providers/terraform-provider-docker
2017-06-05 16:59:08 -04:00
```
Enter the provider directory and build the provider
```sh
2018-05-02 13:33:52 -04:00
$ cd $GOPATH/src/github.com/terraform-providers/terraform-provider-docker
2017-06-05 16:59:08 -04:00
$ make build
```
Using the provider
----------------------
## Fill in for each provider
Developing the Provider
---------------------------
If you wish to work on the provider, you'll first need [Go ](http://www.golang.org ) installed on your machine (version 1.8+ is *required* ). You'll also need to correctly setup a [GOPATH ](http://golang.org/doc/code.html#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.
```sh
2017-11-21 04:14:07 -05:00
$ make build
2017-06-05 16:59:08 -04:00
...
2018-05-02 13:33:52 -04:00
$ $GOPATH/bin/terraform-provider-docker
2017-06-05 16:59:08 -04:00
...
```
In order to test the provider, you can simply run `make test` .
```sh
$ make test
```
In order to run the full suite of Acceptance tests, run `make testacc` .
2018-05-16 12:00:04 -04:00
*Note:* Acceptance tests create a local registry which will be deleted afterwards.
2017-06-05 16:59:08 -04:00
```sh
$ make testacc
2017-11-21 04:14:07 -05:00
```
In order to extend the provider and test it with `terraform` , build the provider as mentioned above with
```sh
$ make build
2017-06-05 16:59:08 -04:00
```
2017-11-21 04:14:07 -05:00
Remove an explicit version of the provider you develop, because `terraform` will fetch
the locally built one in `$GOPATH/bin`
```hcl
2018-05-02 13:33:52 -04:00
provider "docker" {
2017-11-21 04:14:07 -05:00
# version = "~> 0.1.2"
...
}
```
Don't forget to run `terraform init` each time you rebuild the provider. Check [here ](https://www.youtube.com/watch?v=TMmovxyo5sY&t=30m14s ) for a more detailed explanation.
2018-05-02 13:33:52 -04:00
You can check the latest released version of a provider at https://releases.hashicorp.com/terraform-provider-docker/.