Merge pull request #13921 from bernerdschaefer/bs-create-space
providers/heroku: add heroku_space resource
This commit is contained in:
commit
22ed31c7a6
|
@ -25,11 +25,12 @@ func Provider() terraform.ResourceProvider {
|
||||||
},
|
},
|
||||||
|
|
||||||
ResourcesMap: map[string]*schema.Resource{
|
ResourcesMap: map[string]*schema.Resource{
|
||||||
"heroku_app": resourceHerokuApp(),
|
|
||||||
"heroku_addon": resourceHerokuAddon(),
|
"heroku_addon": resourceHerokuAddon(),
|
||||||
|
"heroku_app": resourceHerokuApp(),
|
||||||
|
"heroku_cert": resourceHerokuCert(),
|
||||||
"heroku_domain": resourceHerokuDomain(),
|
"heroku_domain": resourceHerokuDomain(),
|
||||||
"heroku_drain": resourceHerokuDrain(),
|
"heroku_drain": resourceHerokuDrain(),
|
||||||
"heroku_cert": resourceHerokuCert(),
|
"heroku_space": resourceHerokuSpace(),
|
||||||
},
|
},
|
||||||
|
|
||||||
ConfigureFunc: providerConfigure,
|
ConfigureFunc: providerConfigure,
|
||||||
|
|
|
@ -0,0 +1,117 @@
|
||||||
|
package heroku
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"log"
|
||||||
|
|
||||||
|
heroku "github.com/cyberdelia/heroku-go/v3"
|
||||||
|
"github.com/hashicorp/terraform/helper/schema"
|
||||||
|
)
|
||||||
|
|
||||||
|
func resourceHerokuSpace() *schema.Resource {
|
||||||
|
return &schema.Resource{
|
||||||
|
Create: resourceHerokuSpaceCreate,
|
||||||
|
Read: resourceHerokuSpaceRead,
|
||||||
|
Update: resourceHerokuSpaceUpdate,
|
||||||
|
Delete: resourceHerokuSpaceDelete,
|
||||||
|
|
||||||
|
Schema: map[string]*schema.Schema{
|
||||||
|
"name": {
|
||||||
|
Type: schema.TypeString,
|
||||||
|
Required: true,
|
||||||
|
},
|
||||||
|
|
||||||
|
"organization": {
|
||||||
|
Type: schema.TypeString,
|
||||||
|
Required: true,
|
||||||
|
ForceNew: true,
|
||||||
|
},
|
||||||
|
|
||||||
|
"region": {
|
||||||
|
Type: schema.TypeString,
|
||||||
|
Optional: true,
|
||||||
|
ForceNew: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func resourceHerokuSpaceCreate(d *schema.ResourceData, meta interface{}) error {
|
||||||
|
client := meta.(*heroku.Service)
|
||||||
|
|
||||||
|
opts := heroku.SpaceCreateOpts{}
|
||||||
|
opts.Name = d.Get("name").(string)
|
||||||
|
opts.Organization = d.Get("organization").(string)
|
||||||
|
|
||||||
|
if v, ok := d.GetOk("region"); ok {
|
||||||
|
vs := v.(string)
|
||||||
|
opts.Region = &vs
|
||||||
|
}
|
||||||
|
|
||||||
|
space, err := client.SpaceCreate(context.TODO(), opts)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
d.SetId(space.ID)
|
||||||
|
log.Printf("[INFO] Space ID: %s", d.Id())
|
||||||
|
|
||||||
|
// The type conversion here can be dropped when the vendored version of
|
||||||
|
// heroku-go is updated.
|
||||||
|
setSpaceAttributes(d, (*heroku.Space)(space))
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func resourceHerokuSpaceRead(d *schema.ResourceData, meta interface{}) error {
|
||||||
|
client := meta.(*heroku.Service)
|
||||||
|
|
||||||
|
space, err := client.SpaceInfo(context.TODO(), d.Id())
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// The type conversion here can be dropped when the vendored version of
|
||||||
|
// heroku-go is updated.
|
||||||
|
setSpaceAttributes(d, (*heroku.Space)(space))
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func resourceHerokuSpaceUpdate(d *schema.ResourceData, meta interface{}) error {
|
||||||
|
client := meta.(*heroku.Service)
|
||||||
|
|
||||||
|
if !d.HasChange("name") {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
name := d.Get("name").(string)
|
||||||
|
opts := heroku.SpaceUpdateOpts{Name: &name}
|
||||||
|
|
||||||
|
space, err := client.SpaceUpdate(context.TODO(), d.Id(), opts)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// The type conversion here can be dropped when the vendored version of
|
||||||
|
// heroku-go is updated.
|
||||||
|
setSpaceAttributes(d, (*heroku.Space)(space))
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func setSpaceAttributes(d *schema.ResourceData, space *heroku.Space) {
|
||||||
|
d.Set("name", space.Name)
|
||||||
|
d.Set("organization", space.Organization.Name)
|
||||||
|
d.Set("region", space.Region.Name)
|
||||||
|
}
|
||||||
|
|
||||||
|
func resourceHerokuSpaceDelete(d *schema.ResourceData, meta interface{}) error {
|
||||||
|
client := meta.(*heroku.Service)
|
||||||
|
|
||||||
|
log.Printf("[INFO] Deleting space: %s", d.Id())
|
||||||
|
_, err := client.SpaceDelete(context.TODO(), d.Id())
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
d.SetId("")
|
||||||
|
return nil
|
||||||
|
}
|
|
@ -0,0 +1,114 @@
|
||||||
|
package heroku
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
heroku "github.com/cyberdelia/heroku-go/v3"
|
||||||
|
"github.com/hashicorp/terraform/helper/acctest"
|
||||||
|
"github.com/hashicorp/terraform/helper/resource"
|
||||||
|
"github.com/hashicorp/terraform/terraform"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestAccHerokuSpace_Basic(t *testing.T) {
|
||||||
|
var space heroku.SpaceInfoResult
|
||||||
|
spaceName := fmt.Sprintf("tftest-%s", acctest.RandString(10))
|
||||||
|
spaceName2 := fmt.Sprintf("tftest-%s", acctest.RandString(10))
|
||||||
|
org := os.Getenv("HEROKU_ORGANIZATION")
|
||||||
|
|
||||||
|
resource.Test(t, resource.TestCase{
|
||||||
|
PreCheck: func() {
|
||||||
|
testAccPreCheck(t)
|
||||||
|
if org == "" {
|
||||||
|
t.Skip("HEROKU_ORGANIZATION is not set; skipping test.")
|
||||||
|
}
|
||||||
|
},
|
||||||
|
Providers: testAccProviders,
|
||||||
|
CheckDestroy: testAccCheckHerokuSpaceDestroy,
|
||||||
|
Steps: []resource.TestStep{
|
||||||
|
{
|
||||||
|
Config: testAccCheckHerokuSpaceConfig_basic(spaceName, org),
|
||||||
|
Check: resource.ComposeTestCheckFunc(
|
||||||
|
testAccCheckHerokuSpaceExists("heroku_space.foobar", &space),
|
||||||
|
testAccCheckHerokuSpaceAttributes(&space, spaceName),
|
||||||
|
),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Config: testAccCheckHerokuSpaceConfig_basic(spaceName2, org),
|
||||||
|
Check: resource.ComposeTestCheckFunc(
|
||||||
|
testAccCheckHerokuSpaceExists("heroku_space.foobar", &space),
|
||||||
|
testAccCheckHerokuSpaceAttributes(&space, spaceName2),
|
||||||
|
),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func testAccCheckHerokuSpaceConfig_basic(spaceName, orgName string) string {
|
||||||
|
return fmt.Sprintf(`
|
||||||
|
resource "heroku_space" "foobar" {
|
||||||
|
name = "%s"
|
||||||
|
organization = "%s"
|
||||||
|
region = "virginia"
|
||||||
|
}
|
||||||
|
`, spaceName, orgName)
|
||||||
|
}
|
||||||
|
|
||||||
|
func testAccCheckHerokuSpaceExists(n string, space *heroku.SpaceInfoResult) resource.TestCheckFunc {
|
||||||
|
return func(s *terraform.State) error {
|
||||||
|
rs, ok := s.RootModule().Resources[n]
|
||||||
|
|
||||||
|
if !ok {
|
||||||
|
return fmt.Errorf("Not found: %s", n)
|
||||||
|
}
|
||||||
|
|
||||||
|
if rs.Primary.ID == "" {
|
||||||
|
return fmt.Errorf("No space name set")
|
||||||
|
}
|
||||||
|
|
||||||
|
client := testAccProvider.Meta().(*heroku.Service)
|
||||||
|
|
||||||
|
foundSpace, err := client.SpaceInfo(context.TODO(), rs.Primary.ID)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if foundSpace.ID != rs.Primary.ID {
|
||||||
|
return fmt.Errorf("Space not found")
|
||||||
|
}
|
||||||
|
|
||||||
|
*space = *foundSpace
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func testAccCheckHerokuSpaceAttributes(space *heroku.SpaceInfoResult, spaceName string) resource.TestCheckFunc {
|
||||||
|
return func(s *terraform.State) error {
|
||||||
|
if space.Name != spaceName {
|
||||||
|
return fmt.Errorf("Bad name: %s", space.Name)
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func testAccCheckHerokuSpaceDestroy(s *terraform.State) error {
|
||||||
|
client := testAccProvider.Meta().(*heroku.Service)
|
||||||
|
|
||||||
|
for _, rs := range s.RootModule().Resources {
|
||||||
|
if rs.Type != "heroku_space" {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err := client.SpaceInfo(context.TODO(), rs.Primary.ID)
|
||||||
|
|
||||||
|
if err == nil {
|
||||||
|
return fmt.Errorf("Space still exists")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
|
@ -0,0 +1,48 @@
|
||||||
|
---
|
||||||
|
layout: "heroku"
|
||||||
|
page_title: "Heroku: heroku_space"
|
||||||
|
sidebar_current: "docs-heroku-resource-space"
|
||||||
|
description: |-
|
||||||
|
Provides a Heroku Space resource for running apps in isolated, highly available, secure app execution environments.
|
||||||
|
---
|
||||||
|
|
||||||
|
# heroku\_space
|
||||||
|
|
||||||
|
Provides a Heroku Space resource for running apps in isolated, highly available, secure app execution environments.
|
||||||
|
|
||||||
|
## Example Usage
|
||||||
|
|
||||||
|
```hcl
|
||||||
|
// Create a new Heroku space
|
||||||
|
resource "heroku_space" "default" {
|
||||||
|
name = "test-space"
|
||||||
|
organization = "my-company"
|
||||||
|
region = "virginia"
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create a new Heroku app in test-space
|
||||||
|
resource "heroku_app" "default" {
|
||||||
|
name = "test-app"
|
||||||
|
space = "${heroku_space.default.name}"
|
||||||
|
organization = {
|
||||||
|
name = "my-company"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Argument Reference
|
||||||
|
|
||||||
|
The following arguments are supported:
|
||||||
|
|
||||||
|
* `name` - (Required) The name of the space.
|
||||||
|
* `organization` - (Required) The name of the organization which will own the space.
|
||||||
|
* `region` - (Optional) The region that the space should be created in.
|
||||||
|
|
||||||
|
## Attributes Reference
|
||||||
|
|
||||||
|
The following attributes are exported:
|
||||||
|
|
||||||
|
* `id` - The ID of the space.
|
||||||
|
* `name` - The space's name.
|
||||||
|
* `organization` - The space's organization.
|
||||||
|
* `region` - The space's region.
|
|
@ -32,6 +32,10 @@
|
||||||
<li<%= sidebar_current("docs-heroku-resource-drain") %>>
|
<li<%= sidebar_current("docs-heroku-resource-drain") %>>
|
||||||
<a href="/docs/providers/heroku/r/drain.html">heroku_drain</a>
|
<a href="/docs/providers/heroku/r/drain.html">heroku_drain</a>
|
||||||
</li>
|
</li>
|
||||||
|
|
||||||
|
<li<%= sidebar_current("docs-heroku-resource-space") %>>
|
||||||
|
<a href="/docs/providers/heroku/r/space.html">heroku_space</a>
|
||||||
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
Loading…
Reference in New Issue