From 136fbb3bb277becfd5f28668ea22b8254b19874a Mon Sep 17 00:00:00 2001 From: Patrick Rauchfuss Date: Thu, 17 Oct 2024 21:23:25 +0200 Subject: [PATCH] add auto_accept_projects in ncc group (#11828) Co-authored-by: Zhenhua Li --- mmv1/products/networkconnectivity/Group.yaml | 109 ++++++++++++++++++ .../network_connectivity_group_basic.tf.tmpl | 22 ++++ ...esource_network_connectivity_group_test.go | 95 +++++++++++++++ 3 files changed, 226 insertions(+) create mode 100644 mmv1/products/networkconnectivity/Group.yaml create mode 100644 mmv1/templates/terraform/examples/network_connectivity_group_basic.tf.tmpl create mode 100644 mmv1/third_party/terraform/services/networkconnectivity/resource_network_connectivity_group_test.go diff --git a/mmv1/products/networkconnectivity/Group.yaml b/mmv1/products/networkconnectivity/Group.yaml new file mode 100644 index 000000000000..00db44c3de50 --- /dev/null +++ b/mmv1/products/networkconnectivity/Group.yaml @@ -0,0 +1,109 @@ +# Copyright 2024 Google Inc. +# Licensed under the Apache License, Version 2.0 (the License); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +name: Group +legacy_long_form_project: true +base_url: projects/{{project}}/locations/global/hubs/{{hub}}/groups +create_url: projects/{{project}}/locations/global/hubs/{{hub}}/groups/{{name}}?updateMask=autoAccept.autoAcceptProjects,labels,description +update_url: projects/{{project}}/locations/global/hubs/{{hub}}/groups/{{name}}?updateMask=autoAccept.autoAcceptProjects,labels,description +self_link: projects/{{project}}/locations/global/hubs/{{hub}}/groups/{{name}} +create_verb: 'PATCH' +update_verb: 'PATCH' +references: + guides: + 'Official Documentation': 'https://cloud.google.com/network-connectivity/docs/network-connectivity-center/concepts/overview' + api: 'https://cloud.google.com/network-connectivity/docs/reference/networkconnectivity/rest/v1beta/projects.locations.global.hubs.groups' +async: + type: 'OpAsync' + operation: + path: 'name' + base_url: '{{op_id}}' + wait_ms: 1000 + result: + path: 'targetLink' + error: + path: 'error/errors' + message: 'message' +# A handwritten sweeper is needed as the resource name can only be `default`, `center`, and `edge`. +exclude_sweeper: true +examples: + - name: 'network_connectivity_group_basic' + primary_resource_id: 'primary' + vars: + hub_name: "network-connectivity-hub1" + auto_accept_project_1_name: "foo" + auto_accept_project_2_name: "bar" +description: The NetworkConnectivity Group resource +parameters: + - name: 'hub' + type: ResourceRef + resource: 'Hub' + imports: 'id' + description: | + The name of the hub. Hub names must be unique. They use the following form: projects/{projectNumber}/locations/global/hubs/{hubId} + immutable: true + required: true + url_param_only: true + custom_flatten: templates/terraform/custom_flatten/name_from_self_link.erb +properties: + - name: name + type: Enum + description: 'The name of the group. Group names must be unique.' + diff_suppress_func: 'tpgresource.CompareSelfLinkOrResourceName' + required: true + immutable: true + custom_flatten: 'templates/terraform/custom_flatten/name_from_self_link.tmpl' + enum_values: + - 'default' + - 'center' + - 'edge' + - name: createTime + type: String + description: Output only. The time the hub was created. + output: true + - name: updateTime + type: String + description: Output only. The time the hub was last updated. + output: true + - name: labels + type: KeyValueLabels + description: Optional labels in key:value format. For more information about labels, see [Requirements for labels](https://cloud.google.com/resource-manager/docs/creating-managing-labels#requirements). + - name: description + type: String + description: An optional description of the group. + - name: uid + type: String + description: Output only. The Google-generated UUID for the group. This value is unique across all group resources. If a group is deleted and another with the same name is created, the new route table is assigned a different uniqueId. + output: true + - name: state + type: String + description: Output only. The current lifecycle state of this hub. + output: true + exactly_one_of: + - CREATING + - ACTIVE + - DELETING + - name: autoAccept + type: NestedObject + description: Optional. The auto-accept setting for this group. + properties: + - name: autoAcceptProjects + type: Array + description: 'A list of project ids or project numbers for which you want to enable auto-accept. The auto-accept setting is applied to spokes being created or updated in these projects.' + required: true + item_type: + type: String + - name: routeTable + type: String + description: 'Output only. The name of the route table that corresponds to this group. They use the following form: `projects/{projectNumber}/locations/global/hubs/{hubId}/routeTables/{route_table_id}`' + output: true diff --git a/mmv1/templates/terraform/examples/network_connectivity_group_basic.tf.tmpl b/mmv1/templates/terraform/examples/network_connectivity_group_basic.tf.tmpl new file mode 100644 index 000000000000..b3ee2b621624 --- /dev/null +++ b/mmv1/templates/terraform/examples/network_connectivity_group_basic.tf.tmpl @@ -0,0 +1,22 @@ +resource "google_network_connectivity_hub" "basic_hub" { + name = "{{index $.Vars "hub_name"}}" + description = "A sample hub" + labels = { + label-one = "value-one" + } +} + +resource "google_network_connectivity_group" "{{$.PrimaryResourceId}}" { + hub = google_network_connectivity_hub.basic_hub.id + name = "default" + labels = { + label-one = "value-one" + } + description = "A sample hub group" + auto_accept { + auto_accept_projects = [ + "{{index $.Vars "auto_accept_project_1_name"}}", + "{{index $.Vars "auto_accept_project_2_name"}}", + ] + } +} \ No newline at end of file diff --git a/mmv1/third_party/terraform/services/networkconnectivity/resource_network_connectivity_group_test.go b/mmv1/third_party/terraform/services/networkconnectivity/resource_network_connectivity_group_test.go new file mode 100644 index 000000000000..68b531193d0c --- /dev/null +++ b/mmv1/third_party/terraform/services/networkconnectivity/resource_network_connectivity_group_test.go @@ -0,0 +1,95 @@ +package networkconnectivity_test + +import ( + "testing" + + "github.com/hashicorp/terraform-plugin-testing/helper/resource" + + "github.com/hashicorp/terraform-provider-google/google/acctest" + "github.com/hashicorp/terraform-provider-google/google/envvar" +) + +func TestAccNetworkConnectivityGroup_BasicGroup(t *testing.T) { + t.Parallel() + + context := map[string]interface{}{ + "project_name": envvar.GetTestProjectFromEnv(), + "hub_random_suffix": acctest.RandString(t, 10), + "project_random_suffix_1": acctest.RandString(t, 10), + "project_random_suffix_2": acctest.RandString(t, 10), + } + + acctest.VcrTest(t, resource.TestCase{ + PreCheck: func() { acctest.AccTestPreCheck(t) }, + ProtoV5ProviderFactories: acctest.ProtoV5ProviderFactories(t), + CheckDestroy: testAccCheckNetworkConnectivityGroupDestroyProducer(t), + Steps: []resource.TestStep{ + { + Config: testAccNetworkConnectivityGroup_BasicGroup(context), + }, + { + ResourceName: "google_network_connectivity_group.primary", + ImportState: true, + ImportStateVerify: true, + ImportStateVerifyIgnore: []string{"hub", "labels", "terraform_labels"}, + }, + { + Config: testAccNetworkConnectivityGroup_BasicGroupUpdate0(context), + }, + { + ResourceName: "google_network_connectivity_group.primary", + ImportState: true, + ImportStateVerify: true, + ImportStateVerifyIgnore: []string{"hub", "labels", "terraform_labels"}, + }, + }, + }) +} + +func testAccNetworkConnectivityGroup_BasicGroup(context map[string]interface{}) string { + return acctest.Nprintf(` +resource "google_network_connectivity_hub" "basic_hub" { + name = "tf-test-hub%{hub_random_suffix}" + description = "A sample hub" + project = "%{project_name}" + labels = { + label-one = "value-one" + } +} +resource "google_network_connectivity_group" "primary" { + hub = google_network_connectivity_hub.basic_hub.id + name = "default" + labels = { + label-one = "value-one" + } + description = "A sample group" + auto_accept { + auto_accept_projects = ["tf-test-name%{project_random_suffix_1}"] + } +} +`, context) +} + +func testAccNetworkConnectivityGroup_BasicGroupUpdate0(context map[string]interface{}) string { + return acctest.Nprintf(` +resource "google_network_connectivity_hub" "basic_hub" { + name = "tf-test-hub%{hub_random_suffix}" + description = "A sample hub" + project = "%{project_name}" + labels = { + label-one = "value-one" + } +} +resource "google_network_connectivity_group" "primary" { + hub = google_network_connectivity_hub.basic_hub.id + name = "default" + labels = { + label-two = "value-one" + } + description = "An updated sample group" + auto_accept { + auto_accept_projects = ["tf-test-name%{project_random_suffix_1}", "tf-test-name%{project_random_suffix_2}"] + } +} +`, context) +}