Skip to content

Commit

Permalink
Fix ApigeeOrganization update response type. (#12413)
Browse files Browse the repository at this point in the history
  • Loading branch information
masich authored Jan 8, 2025
1 parent 716d7b6 commit c13527d
Show file tree
Hide file tree
Showing 2 changed files with 212 additions and 1 deletion.
2 changes: 1 addition & 1 deletion mmv1/products/apigee/Organization.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ timeouts:
delete_minutes: 45
autogen_async: true
async:
actions: ['create', 'delete', 'update']
actions: ['create', 'delete']
type: 'OpAsync'
operation:
base_url: '{{op_id}}'
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,211 @@
package apigee_test

import (
"maps"
"testing"

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

"github.com/hashicorp/terraform-plugin-testing/plancheck"
"github.com/hashicorp/terraform-provider-google/google/acctest"
"github.com/hashicorp/terraform-provider-google/google/envvar"
)

func TestAccApigeeOrganization_update(t *testing.T) {
acctest.SkipIfVcr(t)
t.Parallel()

default_context := map[string]interface{}{
"billing_account": envvar.GetTestBillingAccountFromEnv(t),
"org_id": envvar.GetTestOrgFromEnv(t),
"random_suffix": acctest.RandString(t, 10),
}
update_context := maps.Clone(default_context)
update_context["org_description"] = "Updated Apigee Org description."

acctest.VcrTest(t, resource.TestCase{
PreCheck: func() { acctest.AccTestPreCheck(t) },
ProtoV5ProviderFactories: acctest.ProtoV5ProviderFactories(t),
Steps: []resource.TestStep{
{
Config: testAccApigeeOrganization_full(default_context),
},
{
ResourceName: "google_apigee_organization.apigee_org",
ImportState: true,
ImportStateVerify: true,
ImportStateVerifyIgnore: []string{"project_id", "properties", "retention"},
},
{
Config: testAccApigeeOrganization_update(update_context),
ConfigPlanChecks: resource.ConfigPlanChecks{
PreApply: []plancheck.PlanCheck{
plancheck.ExpectResourceAction("google_apigee_organization.apigee_org", plancheck.ResourceActionUpdate),
},
},
},
{
ResourceName: "google_apigee_organization.apigee_org",
ImportState: true,
ImportStateVerify: true,
ImportStateVerifyIgnore: []string{"project_id", "properties", "retention"},
},
},
})
}

func testAccApigeeOrganization_full(context map[string]interface{}) string {
return acctest.Nprintf(`
resource "google_project" "project" {
provider = google
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" {
provider = google
project = google_project.project.project_id
service = "apigee.googleapis.com"
}
resource "google_project_service" "compute" {
provider = google
project = google_project.project.project_id
service = "compute.googleapis.com"
}
resource "google_project_service" "servicenetworking" {
provider = google
project = google_project.project.project_id
service = "servicenetworking.googleapis.com"
}
resource "google_compute_network" "apigee_network" {
provider = google
name = "apigee-network"
project = google_project.project.project_id
depends_on = [google_project_service.compute]
}
resource "google_compute_global_address" "apigee_range" {
provider = google
name = "apigee-range"
purpose = "VPC_PEERING"
address_type = "INTERNAL"
prefix_length = 21
network = google_compute_network.apigee_network.id
project = google_project.project.project_id
}
resource "google_service_networking_connection" "apigee_vpc_connection" {
provider = google
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" {
provider = google
display_name = "apigee-org"
analytics_region = "us-central1"
description = "Terraform-managed Apigee Org"
project_id = google_project.project.project_id
authorized_network = google_compute_network.apigee_network.id
billing_type = "EVALUATION"
depends_on = [
google_service_networking_connection.apigee_vpc_connection,
google_project_service.apigee,
]
}
`, context)
}

func testAccApigeeOrganization_update(context map[string]interface{}) string {
return acctest.Nprintf(`
resource "google_project" "project" {
provider = google
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" {
provider = google
project = google_project.project.project_id
service = "apigee.googleapis.com"
}
resource "google_project_service" "compute" {
provider = google
project = google_project.project.project_id
service = "compute.googleapis.com"
}
resource "google_project_service" "servicenetworking" {
provider = google
project = google_project.project.project_id
service = "servicenetworking.googleapis.com"
}
resource "google_compute_network" "apigee_network" {
provider = google
name = "apigee-network"
project = google_project.project.project_id
depends_on = [google_project_service.compute]
}
resource "google_compute_global_address" "apigee_range" {
provider = google
name = "apigee-range"
purpose = "VPC_PEERING"
address_type = "INTERNAL"
prefix_length = 21
network = google_compute_network.apigee_network.id
project = google_project.project.project_id
}
resource "google_service_networking_connection" "apigee_vpc_connection" {
provider = google
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" {
provider = google
display_name = "apigee-org"
analytics_region = "us-central1"
description = "%{org_description}"
project_id = google_project.project.project_id
authorized_network = google_compute_network.apigee_network.id
billing_type = "EVALUATION"
depends_on = [
google_service_networking_connection.apigee_vpc_connection,
google_project_service.apigee,
]
}
`, context)
}

0 comments on commit c13527d

Please sign in to comment.