From 608a306824142004cd46da505234291341941786 Mon Sep 17 00:00:00 2001 From: tulika-aakriti Date: Tue, 15 Oct 2024 19:18:08 +0530 Subject: [PATCH] Feat: Add google_oracle_database_cloud_exadata_infrastructure datasource (#11996) --- .../provider/provider_mmv1_resources.go.tmpl | 1 + ...e_database_cloud_exadata_infrastructure.go | 36 ++++++++++++++++ ...abase_cloud_exadata_infrastructure_test.go | 42 +++++++++++++++++++ ...cloud_exadata_infrastructure.html.markdown | 34 +++++++++++++++ 4 files changed, 113 insertions(+) create mode 100644 mmv1/third_party/terraform/services/oracledatabase/data_source_oracle_database_cloud_exadata_infrastructure.go create mode 100644 mmv1/third_party/terraform/services/oracledatabase/data_source_oracle_database_cloud_exadata_infrastructure_test.go create mode 100644 mmv1/third_party/terraform/website/docs/d/oracle_database_cloud_exadata_infrastructure.html.markdown diff --git a/mmv1/third_party/terraform/provider/provider_mmv1_resources.go.tmpl b/mmv1/third_party/terraform/provider/provider_mmv1_resources.go.tmpl index 9c319b99220a..b7a75e87b30e 100644 --- a/mmv1/third_party/terraform/provider/provider_mmv1_resources.go.tmpl +++ b/mmv1/third_party/terraform/provider/provider_mmv1_resources.go.tmpl @@ -169,6 +169,7 @@ var handwrittenDatasources = map[string]*schema.Resource{ "google_monitoring_uptime_check_ips": monitoring.DataSourceGoogleMonitoringUptimeCheckIps(), "google_netblock_ip_ranges": resourcemanager.DataSourceGoogleNetblockIpRanges(), "google_oracle_database_db_servers": oracledatabase.DataSourceOracleDatabaseDbServers(), + "google_oracle_database_cloud_exadata_infrastructure":oracledatabase.DataSourceOracleDatabaseCloudExadataInfrastructure(), "google_organization": resourcemanager.DataSourceGoogleOrganization(), "google_privateca_certificate_authority": privateca.DataSourcePrivatecaCertificateAuthority(), "google_privileged_access_manager_entitlement": privilegedaccessmanager.DataSourceGooglePrivilegedAccessManagerEntitlement(), diff --git a/mmv1/third_party/terraform/services/oracledatabase/data_source_oracle_database_cloud_exadata_infrastructure.go b/mmv1/third_party/terraform/services/oracledatabase/data_source_oracle_database_cloud_exadata_infrastructure.go new file mode 100644 index 000000000000..b0cc4e8684d2 --- /dev/null +++ b/mmv1/third_party/terraform/services/oracledatabase/data_source_oracle_database_cloud_exadata_infrastructure.go @@ -0,0 +1,36 @@ +package oracledatabase + +import ( + "fmt" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" + "github.com/hashicorp/terraform-provider-google/google/tpgresource" + transport_tpg "github.com/hashicorp/terraform-provider-google/google/transport" +) + +func DataSourceOracleDatabaseCloudExadataInfrastructure() *schema.Resource { + dsSchema := tpgresource.DatasourceSchemaFromResourceSchema(ResourceOracleDatabaseCloudExadataInfrastructure().Schema) + tpgresource.AddRequiredFieldsToSchema(dsSchema, "location", "cloud_exadata_infrastructure_id") + tpgresource.AddOptionalFieldsToSchema(dsSchema, "project") + return &schema.Resource{ + Read: dataSourceOracleDatabaseCloudExadataInfrastructureRead, + Schema: dsSchema, + } + +} + +func dataSourceOracleDatabaseCloudExadataInfrastructureRead(d *schema.ResourceData, meta interface{}) error { + config := meta.(*transport_tpg.Config) + + id, err := tpgresource.ReplaceVars(d, config, "projects/{{project}}/locations/{{location}}/cloudExadataInfrastructures/{{cloud_exadata_infrastructure_id}}") + if err != nil { + return fmt.Errorf("Error constructing id: %s", err) + } + err = resourceOracleDatabaseCloudExadataInfrastructureRead(d, meta) + if err != nil { + return err + } + d.SetId(id) + + return nil +} diff --git a/mmv1/third_party/terraform/services/oracledatabase/data_source_oracle_database_cloud_exadata_infrastructure_test.go b/mmv1/third_party/terraform/services/oracledatabase/data_source_oracle_database_cloud_exadata_infrastructure_test.go new file mode 100644 index 000000000000..ac0f3cdb3143 --- /dev/null +++ b/mmv1/third_party/terraform/services/oracledatabase/data_source_oracle_database_cloud_exadata_infrastructure_test.go @@ -0,0 +1,42 @@ +package oracledatabase_test + +import ( + "fmt" + "github.com/hashicorp/terraform-plugin-testing/helper/resource" + "github.com/hashicorp/terraform-provider-google/google/acctest" + "testing" +) + +func TestAccOracleDatabaseCloudExadataInfrastructure_basic(t *testing.T) { + t.Parallel() + acctest.VcrTest(t, resource.TestCase{ + PreCheck: func() { acctest.AccTestPreCheck(t) }, + ProtoV5ProviderFactories: acctest.ProtoV5ProviderFactories(t), + Steps: []resource.TestStep{ + { + Config: testAccOracleDatabaseCloudExadataInfrastructure_basic(), + Check: resource.ComposeTestCheckFunc( + resource.TestCheckResourceAttrSet("data.google_oracle_database_cloud_exadata_infrastructure.my-exadata", "display_name"), + resource.TestCheckResourceAttrSet("data.google_oracle_database_cloud_exadata_infrastructure.my-exadata", "name"), + resource.TestCheckResourceAttrSet("data.google_oracle_database_cloud_exadata_infrastructure.my-exadata", "gcp_oracle_zone"), + resource.TestCheckResourceAttrSet("data.google_oracle_database_cloud_exadata_infrastructure.my-exadata", "properties.#"), + resource.TestCheckResourceAttrSet("data.google_oracle_database_cloud_exadata_infrastructure.my-exadata", "properties.0.compute_count"), + resource.TestCheckResourceAttr("data.google_oracle_database_cloud_exadata_infrastructure.my-exadata", "display_name", "ofake-exadata-for-vm display name"), + resource.TestCheckResourceAttr("data.google_oracle_database_cloud_exadata_infrastructure.my-exadata", "gcp_oracle_zone", "us-east4-b-r1"), + resource.TestCheckResourceAttr("data.google_oracle_database_cloud_exadata_infrastructure.my-exadata", "properties.0.state", "AVAILABLE"), + resource.TestCheckResourceAttr("data.google_oracle_database_cloud_exadata_infrastructure.my-exadata", "properties.0.shape", "Exadata.X9M"), + ), + }, + }, + }) +} + +func testAccOracleDatabaseCloudExadataInfrastructure_basic() string { + return fmt.Sprintf(` +data "google_oracle_database_cloud_exadata_infrastructure" "my-exadata"{ + cloud_exadata_infrastructure_id = "ofake-do-not-delete-tf-exadata" + project = "oci-terraform-testing" + location = "us-east4" +} +`) +} diff --git a/mmv1/third_party/terraform/website/docs/d/oracle_database_cloud_exadata_infrastructure.html.markdown b/mmv1/third_party/terraform/website/docs/d/oracle_database_cloud_exadata_infrastructure.html.markdown new file mode 100644 index 000000000000..035a9fe9708d --- /dev/null +++ b/mmv1/third_party/terraform/website/docs/d/oracle_database_cloud_exadata_infrastructure.html.markdown @@ -0,0 +1,34 @@ +--- +subcategory: "Oracle Database" +description: |- + Get information about an ExadataInfrastructure. +--- + +# google_oracle_database_cloud_exadata_infrastructure + +Get information about an ExadataInfrastructure. + +## Example Usage + +```hcl +data "google_oracle_database_cloud_exadata_infrastructure" "my-instance"{ + location = "us-east4" + cloud_exadata_infrastructure_id = "exadata-id" +} +``` + +## Argument Reference + +The following arguments are supported: + +* `cloud_exadata_infrastructure_id` - (Required) The ID of the ExadataInfrastructure. + +* `location` - (Required) The location of the resource. + +- - - +* `project` - (Optional) The project to which the resource belongs. If it + is not provided, the provider project is used. + +## Attributes Reference + +See [google_oracle_database_cloud_exadata_infrastructure](https://registry.terraform.io/providers/hashicorp/google/latest/docs/resources/google_oracle_database_cloud_exadata_infrastructure#argument-reference) resource for details of the available attributes. \ No newline at end of file