Skip to content

Commit

Permalink
metastore dataproc service data source (#5763) (#4155)
Browse files Browse the repository at this point in the history
* metastore dataproc service data source

* provider

* docs

* test name

* location optional

* revert location and make required

* docs

* docs

* tf test

Signed-off-by: Modular Magician <magic-modules@google.com>
  • Loading branch information
modular-magician authored Mar 28, 2022
1 parent caccf10 commit 9703ccd
Show file tree
Hide file tree
Showing 6 changed files with 129 additions and 0 deletions.
3 changes: 3 additions & 0 deletions .changelog/5763.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
```release-note:new-datasource
dataproc_metastore_service
```
29 changes: 29 additions & 0 deletions google-beta/data_source_dataproc_metastore_service.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
package google

import (
"fmt"

"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
)

func dataSourceDataprocMetastoreService() *schema.Resource {

dsSchema := datasourceSchemaFromResourceSchema(resourceDataprocMetastoreService().Schema)
addRequiredFieldsToSchema(dsSchema, "service_id")
addRequiredFieldsToSchema(dsSchema, "location")
addOptionalFieldsToSchema(dsSchema, "project")

return &schema.Resource{
Read: dataSourceDataprocMetastoreServiceRead,
Schema: dsSchema,
}
}

func dataSourceDataprocMetastoreServiceRead(d *schema.ResourceData, meta interface{}) error {
id, err := replaceVars(d, meta.(*Config), "projects/{{project}}/locations/{{location}}/services/{{service_id}}")
if err != nil {
return fmt.Errorf("Error constructing id: %s", err)
}
d.SetId(id)
return resourceDataprocMetastoreServiceRead(d, meta)
}
46 changes: 46 additions & 0 deletions google-beta/data_source_dataproc_metastore_service_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
package google

import (
"fmt"
"testing"

"github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource"
)

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

name := "tf-test-" + randString(t, 10)

vcrTest(t, resource.TestCase{
PreCheck: func() { testAccPreCheck(t) },
Providers: testAccProviders,
Steps: []resource.TestStep{
{
Config: testAccDataprocMetastoreServiceDatasource_basic(name, "DEVELOPER"),
Check: resource.ComposeTestCheckFunc(
checkDataSourceStateMatchesResourceState("data.google_dataproc_metastore_service.my_metastore", "google_dataproc_metastore_service.my_metastore"),
),
},
},
})
}

func testAccDataprocMetastoreServiceDatasource_basic(name, tier string) string {
return fmt.Sprintf(`
resource "google_dataproc_metastore_service" "my_metastore" {
service_id = "%s"
location = "us-central1"
tier = "%s"
hive_metastore_config {
version = "2.3.6"
}
}
data "google_dataproc_metastore_service" "my_metastore" {
service_id = google_dataproc_metastore_service.my_metastore.service_id
location = google_dataproc_metastore_service.my_metastore.location
}
`, name, tier)
}
1 change: 1 addition & 0 deletions google-beta/provider.go
Original file line number Diff line number Diff line change
Expand Up @@ -846,6 +846,7 @@ func Provider() *schema.Provider {
"google_container_engine_versions": dataSourceGoogleContainerEngineVersions(),
"google_container_registry_image": dataSourceGoogleContainerImage(),
"google_container_registry_repository": dataSourceGoogleContainerRepo(),
"google_dataproc_metastore_service": dataSourceDataprocMetastoreService(),
"google_dns_keys": dataSourceDNSKeys(),
"google_dns_managed_zone": dataSourceDnsManagedZone(),
"google_dns_record_set": dataSourceDnsRecordSet(),
Expand Down
40 changes: 40 additions & 0 deletions website/docs/d/data_source_dataproc_metastore_service.markdown
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
---
subcategory: "Dataproc"
layout: "google"
page_title: "Google: google_dataproc_metastore_service"
sidebar_current: "docs-google-datasource-dataproc-metastore-service"
description: |-
Get a Dataproc Metastore Service from Google Cloud
---

# google\_dataproc\_metastore\_service

Get a Dataproc Metastore service from Google Cloud by its id and location.

~> **Warning:** This resource is in beta, and should be used with the terraform-provider-google-beta provider.
See [Provider Versions](https://terraform.io/docs/providers/google/guides/provider_versions.html) for more details on beta resources.

## Example Usage

```tf
data "google_dataproc_metastore_service" "foo" {
service_id = "foo-bar"
location = "global"
}
```

## Argument Reference

The following arguments are supported:

* `service_id` - (Required) The ID of the metastore service.
* `location` - (Required) The location where the metastore service resides.

- - -

* `project` - (Optional) The project in which the resource belongs. If it
is not provided, the provider project is used.

## Attributes Reference

See [google_dataproc_metastore_service](https://www.terraform.io/docs/providers/google/r/dataproc_metastore_service.html) resource for details of all the available attributes.
10 changes: 10 additions & 0 deletions website/google.erb
Original file line number Diff line number Diff line change
Expand Up @@ -2395,6 +2395,16 @@
<li>
<a href="#">Dataproc</a>
<ul class="nav">
<li>
<a href="#">Data Sources</a>
<ul class="nav nav-auto-expand">

<li>
<a href="/docs/providers/google/d/data_source_dataproc_metastore_service">google_dataproc_metastore_service</a>
</li>

</ul>
</li>
<li>
<a href="#">Resources</a>
<ul class="nav nav-auto-expand">
Expand Down

0 comments on commit 9703ccd

Please sign in to comment.