Skip to content

Enable update in apigee reference #8621

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions .changelog/11865.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
```release-note:enhancement
apigee: added update support for `google_apigee_env_references`
```
71 changes: 70 additions & 1 deletion google-beta/services/apigee/resource_apigee_env_references.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ func ResourceApigeeEnvReferences() *schema.Resource {
return &schema.Resource{
Create: resourceApigeeEnvReferencesCreate,
Read: resourceApigeeEnvReferencesRead,
Update: resourceApigeeEnvReferencesUpdate,
Delete: resourceApigeeEnvReferencesDelete,

Importer: &schema.ResourceImporter{
Expand All @@ -42,6 +43,7 @@ func ResourceApigeeEnvReferences() *schema.Resource {

Timeouts: &schema.ResourceTimeout{
Create: schema.DefaultTimeout(1 * time.Minute),
Update: schema.DefaultTimeout(20 * time.Minute),
Delete: schema.DefaultTimeout(1 * time.Minute),
},

Expand All @@ -62,7 +64,6 @@ in the format 'organizations/{{org_name}}/environments/{{env_name}}'.`,
"refers": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
Description: `Required. The id of the resource to which this reference refers. Must be the id of a resource that exists in the parent environment and is of the given resourceType.`,
},
"resource_type": {
Expand Down Expand Up @@ -203,6 +204,74 @@ func resourceApigeeEnvReferencesRead(d *schema.ResourceData, meta interface{}) e
return nil
}

func resourceApigeeEnvReferencesUpdate(d *schema.ResourceData, meta interface{}) error {
config := meta.(*transport_tpg.Config)
userAgent, err := tpgresource.GenerateUserAgentString(d, config.UserAgent)
if err != nil {
return err
}

billingProject := ""

obj := make(map[string]interface{})
nameProp, err := expandApigeeEnvReferencesName(d.Get("name"), d, config)
if err != nil {
return err
} else if v, ok := d.GetOkExists("name"); !tpgresource.IsEmptyValue(reflect.ValueOf(v)) && (ok || !reflect.DeepEqual(v, nameProp)) {
obj["name"] = nameProp
}
descriptionProp, err := expandApigeeEnvReferencesDescription(d.Get("description"), d, config)
if err != nil {
return err
} else if v, ok := d.GetOkExists("description"); !tpgresource.IsEmptyValue(reflect.ValueOf(v)) && (ok || !reflect.DeepEqual(v, descriptionProp)) {
obj["description"] = descriptionProp
}
resourceTypeProp, err := expandApigeeEnvReferencesResourceType(d.Get("resource_type"), d, config)
if err != nil {
return err
} else if v, ok := d.GetOkExists("resource_type"); !tpgresource.IsEmptyValue(reflect.ValueOf(v)) && (ok || !reflect.DeepEqual(v, resourceTypeProp)) {
obj["resourceType"] = resourceTypeProp
}
refersProp, err := expandApigeeEnvReferencesRefers(d.Get("refers"), d, config)
if err != nil {
return err
} else if v, ok := d.GetOkExists("refers"); !tpgresource.IsEmptyValue(reflect.ValueOf(v)) && (ok || !reflect.DeepEqual(v, refersProp)) {
obj["refers"] = refersProp
}

url, err := tpgresource.ReplaceVars(d, config, "{{ApigeeBasePath}}{{env_id}}/references/{{name}}")
if err != nil {
return err
}

log.Printf("[DEBUG] Updating EnvReferences %q: %#v", d.Id(), obj)
headers := make(http.Header)

// err == nil indicates that the billing_project value was found
if bp, err := tpgresource.GetBillingProject(d, config); err == nil {
billingProject = bp
}

res, err := transport_tpg.SendRequest(transport_tpg.SendRequestOptions{
Config: config,
Method: "PUT",
Project: billingProject,
RawURL: url,
UserAgent: userAgent,
Body: obj,
Timeout: d.Timeout(schema.TimeoutUpdate),
Headers: headers,
})

if err != nil {
return fmt.Errorf("Error updating EnvReferences %q: %s", d.Id(), err)
} else {
log.Printf("[DEBUG] Finished updating EnvReferences %q: %#v", d.Id(), res)
}

return resourceApigeeEnvReferencesRead(d, meta)
}

func resourceApigeeEnvReferencesDelete(d *schema.ResourceData, meta interface{}) error {
config := meta.(*transport_tpg.Config)
userAgent, err := tpgresource.GenerateUserAgentString(d, config.UserAgent)
Expand Down
222 changes: 222 additions & 0 deletions google-beta/services/apigee/resource_apigee_env_references_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,222 @@
// Copyright (c) HashiCorp, Inc.
// SPDX-License-Identifier: MPL-2.0
package apigee_test

import (
"testing"

"github.com/hashicorp/terraform-plugin-testing/helper/resource"

"github.com/hashicorp/terraform-provider-google-beta/google-beta/acctest"
"github.com/hashicorp/terraform-provider-google-beta/google-beta/envvar"
)

func TestAccApigeeEnvReferences_apigeeEnvironmentReferenceTest_Update(t *testing.T) {
t.Parallel()

context := map[string]interface{}{
"billing_account": envvar.GetTestBillingAccountFromEnv(t),
"org_id": envvar.GetTestOrgFromEnv(t),
"random_suffix": acctest.RandString(t, 10),
}

acctest.VcrTest(t, resource.TestCase{
PreCheck: func() { acctest.AccTestPreCheck(t) },
ProtoV5ProviderFactories: acctest.ProtoV5ProviderFactories(t),
CheckDestroy: testAccCheckApigeeEnvReferencesDestroyProducer(t),
Steps: []resource.TestStep{
{
Config: testAccApigeeEnvReferences_apigeeEnvironmentReferenceTest_full(context),
},
{
ResourceName: "google_apigee_env_references.apigee_environment_reference",
ImportState: true,
ImportStateVerify: true,
ImportStateVerifyIgnore: []string{"env_id"},
},
{
Config: testAccApigeeEnvReferences_apigeeEnvironmentReferenceTest_update(context),
},
{
ResourceName: "google_apigee_env_references.apigee_environment_reference",
ImportState: true,
ImportStateVerify: true,
ImportStateVerifyIgnore: []string{"env_id"},
},
},
})
}

func testAccApigeeEnvReferences_apigeeEnvironmentReferenceTest_full(context map[string]interface{}) string {
return acctest.Nprintf(`
resource "google_project" "project" {
project_id = "tf-test%{random_suffix}"
name = "tf-test%{random_suffix}"
org_id = "%{org_id}"
billing_account = "%{billing_account}"
deletion_policy = "DELETE"
}

resource "google_project_service" "apigee" {
project = google_project.project.project_id
service = "apigee.googleapis.com"
}

resource "google_project_service" "servicenetworking" {
project = google_project.project.project_id
service = "servicenetworking.googleapis.com"
depends_on = [google_project_service.apigee]
}

resource "google_project_service" "compute" {
project = google_project.project.project_id
service = "compute.googleapis.com"
depends_on = [google_project_service.servicenetworking]
}

resource "google_compute_network" "apigee_network" {
name = "apigee-network"
project = google_project.project.project_id
depends_on = [google_project_service.compute]
}

resource "google_compute_global_address" "apigee_range" {
name = "apigee-range"
purpose = "VPC_PEERING"
address_type = "INTERNAL"
prefix_length = 16
network = google_compute_network.apigee_network.id
project = google_project.project.project_id
}

resource "google_service_networking_connection" "apigee_vpc_connection" {
network = google_compute_network.apigee_network.id
service = "servicenetworking.googleapis.com"
reserved_peering_ranges = [google_compute_global_address.apigee_range.name]
depends_on = [google_project_service.servicenetworking]
}

resource "google_apigee_organization" "apigee_org" {
analytics_region = "us-central1"
project_id = google_project.project.project_id
authorized_network = google_compute_network.apigee_network.id
depends_on = [
google_service_networking_connection.apigee_vpc_connection,
google_project_service.apigee,
]
}

resource "google_apigee_environment" "apigee_environment" {
org_id = google_apigee_organization.apigee_org.id
name = "tf-test%{random_suffix}"
description = "Apigee Environment"
display_name = "environment-1"
}

resource "google_apigee_env_keystore" "apigee_environment_keystore_1" {
name = "tf-test-keystore1%{random_suffix}"
env_id = google_apigee_environment.apigee_environment.id
}

resource "google_apigee_env_references" "apigee_environment_reference" {
env_id = google_apigee_environment.apigee_environment.id
name = "tf-test-reference%{random_suffix}"
resource_type = "KeyStore"
refers = google_apigee_env_keystore.apigee_environment_keystore_1.name
depends_on = [google_apigee_env_keystore.apigee_environment_keystore_1]
}

resource "google_apigee_env_keystore" "apigee_environment_keystore_2" {
name = "tf-test-keystore2%{random_suffix}"
env_id = google_apigee_environment.apigee_environment.id
depends_on = [google_apigee_env_references.apigee_environment_reference]
}
`, context)
}

func testAccApigeeEnvReferences_apigeeEnvironmentReferenceTest_update(context map[string]interface{}) string {
return acctest.Nprintf(`
resource "google_project" "project" {
project_id = "tf-test%{random_suffix}"
name = "tf-test%{random_suffix}"
org_id = "%{org_id}"
billing_account = "%{billing_account}"
deletion_policy = "DELETE"
}

resource "google_project_service" "apigee" {
project = google_project.project.project_id
service = "apigee.googleapis.com"
}

resource "google_project_service" "servicenetworking" {
project = google_project.project.project_id
service = "servicenetworking.googleapis.com"
depends_on = [google_project_service.apigee]
}

resource "google_project_service" "compute" {
project = google_project.project.project_id
service = "compute.googleapis.com"
depends_on = [google_project_service.servicenetworking]
}

resource "google_compute_network" "apigee_network" {
name = "apigee-network"
project = google_project.project.project_id
depends_on = [google_project_service.compute]
}

resource "google_compute_global_address" "apigee_range" {
name = "apigee-range"
purpose = "VPC_PEERING"
address_type = "INTERNAL"
prefix_length = 16
network = google_compute_network.apigee_network.id
project = google_project.project.project_id
}

resource "google_service_networking_connection" "apigee_vpc_connection" {
network = google_compute_network.apigee_network.id
service = "servicenetworking.googleapis.com"
reserved_peering_ranges = [google_compute_global_address.apigee_range.name]
depends_on = [google_project_service.servicenetworking]
}

resource "google_apigee_organization" "apigee_org" {
analytics_region = "us-central1"
project_id = google_project.project.project_id
authorized_network = google_compute_network.apigee_network.id
depends_on = [
google_service_networking_connection.apigee_vpc_connection,
google_project_service.apigee,
]
}

resource "google_apigee_environment" "apigee_environment" {
org_id = google_apigee_organization.apigee_org.id
name = "tf-test%{random_suffix}"
description = "Apigee Environment"
display_name = "environment-1"
}

resource "google_apigee_env_keystore" "apigee_environment_keystore_2" {
name = "tf-test-keystore2%{random_suffix}"
env_id = google_apigee_environment.apigee_environment.id
}

resource "google_apigee_env_references" "apigee_environment_reference" {
env_id = google_apigee_environment.apigee_environment.id
name = "tf-test-reference%{random_suffix}"
resource_type = "KeyStore"
refers = google_apigee_env_keystore.apigee_environment_keystore_2.name
depends_on = [google_apigee_env_keystore.apigee_environment_keystore_2]
}

resource "google_apigee_env_keystore" "apigee_environment_keystore_1" {
name = "tf-test-keystore1%{random_suffix}"
env_id = google_apigee_environment.apigee_environment.id
depends_on = [google_apigee_env_references.apigee_environment_reference]
}
`, context)
}
1 change: 1 addition & 0 deletions website/docs/r/apigee_env_references.html.markdown
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,7 @@ This resource provides the following
[Timeouts](https://developer.hashicorp.com/terraform/plugin/sdkv2/resources/retries-and-customizable-timeouts) configuration options:

- `create` - Default is 1 minutes.
- `update` - Default is 20 minutes.
- `delete` - Default is 1 minutes.

## Import
Expand Down