From 4993fd14d3cd8966a1462fc472e5ef32008854e9 Mon Sep 17 00:00:00 2001 From: Modular Magician Date: Mon, 16 Dec 2024 01:15:28 +0000 Subject: [PATCH] compute: added `network_id` to `google_compute_network` (#12504) [upstream:219edef6198ad089672bcea662015ea5a3e3594a] Signed-off-by: Modular Magician --- .changelog/12504.txt | 6 ++++++ .../data_source_google_compute_network.go | 17 ++++++++++++----- .../data_source_google_compute_network_test.go | 1 + .../compute/resource_compute_network.go | 13 +++++++++++++ .../compute/resource_compute_network_test.go | 1 + website/docs/d/compute_network.html.markdown | 4 +++- website/docs/r/compute_network.html.markdown | 6 ++++++ 7 files changed, 42 insertions(+), 6 deletions(-) create mode 100644 .changelog/12504.txt diff --git a/.changelog/12504.txt b/.changelog/12504.txt new file mode 100644 index 00000000000..bbceaab0872 --- /dev/null +++ b/.changelog/12504.txt @@ -0,0 +1,6 @@ +```release-note:enhancement +compute: added `network_id` (integer) to `google_compute_network` resource and data source +``` +```release-note: deprecation +compute: deprecated `numeric_id` (string) field in `google_compute_network` resource. Use the new `network_id` (integer) field instead +``` \ No newline at end of file diff --git a/google/services/compute/data_source_google_compute_network.go b/google/services/compute/data_source_google_compute_network.go index 67307b1b793..a6532bf5018 100644 --- a/google/services/compute/data_source_google_compute_network.go +++ b/google/services/compute/data_source_google_compute_network.go @@ -26,14 +26,18 @@ func DataSourceGoogleComputeNetwork() *schema.Resource { Computed: true, }, - // TODO: this should eventually be TypeInt, but leaving as - // string for now to match the resource and to avoid a - // breaking change. - "numeric_id": { - Type: schema.TypeString, + "network_id": { + Type: schema.TypeInt, Computed: true, }, + // Deprecated in favor of network_id + "numeric_id": { + Type: schema.TypeString, + Computed: true, + Deprecated: "`numeric_id` is deprecated and will be removed in a future major release. Use `network_id` instead.", + }, + "gateway_ipv4": { Type: schema.TypeString, Computed: true, @@ -94,6 +98,9 @@ func dataSourceGoogleComputeNetworkRead(d *schema.ResourceData, meta interface{} if err := d.Set("description", network.Description); err != nil { return fmt.Errorf("Error setting description: %s", err) } + if err := d.Set("network_id", network.Id); err != nil { + return fmt.Errorf("Error setting network_id: %s", err) + } if err := d.Set("numeric_id", strconv.Itoa(int(network.Id))); err != nil { return fmt.Errorf("Error setting numeric_id: %s", err) } diff --git a/google/services/compute/data_source_google_compute_network_test.go b/google/services/compute/data_source_google_compute_network_test.go index 60210c0114c..2340dfe9b5f 100644 --- a/google/services/compute/data_source_google_compute_network_test.go +++ b/google/services/compute/data_source_google_compute_network_test.go @@ -47,6 +47,7 @@ func testAccDataSourceGoogleNetworkCheck(data_source_name string, resource_name network_attrs_to_test := []string{ "id", "name", + "network_id", "numeric_id", "description", "internal_ipv6_range", diff --git a/google/services/compute/resource_compute_network.go b/google/services/compute/resource_compute_network.go index 9a3fb012ee1..601002b5920 100644 --- a/google/services/compute/resource_compute_network.go +++ b/google/services/compute/resource_compute_network.go @@ -142,9 +142,15 @@ subnetworks of this network, across regions. Possible values: ["REGIONAL", "GLOB Description: `The gateway address for default routing out of the network. This value is selected by GCP.`, }, + "network_id": { + Type: schema.TypeString, + Computed: true, + Description: `The unique identifier for the resource. This identifier is defined by the server.`, + }, "numeric_id": { Type: schema.TypeString, Computed: true, + Deprecated: "`numeric_id` is deprecated and will be removed in a future major release. Use `network_id` instead.", Description: `The unique identifier for the resource. This identifier is defined by the server.`, }, "delete_default_routes_on_create": { @@ -388,6 +394,9 @@ func resourceComputeNetworkRead(d *schema.ResourceData, meta interface{}) error if err := d.Set("name", flattenComputeNetworkName(res["name"], d, config)); err != nil { return fmt.Errorf("Error reading Network: %s", err) } + if err := d.Set("network_id", flattenComputeNetworkNetworkId(res["id"], d, config)); err != nil { + return fmt.Errorf("Error reading Network: %s", err) + } if err := d.Set("numeric_id", flattenComputeNetworkNumericId(res["numericId"], d, config)); err != nil { return fmt.Errorf("Error reading Network: %s", err) } @@ -600,6 +609,10 @@ func flattenComputeNetworkName(v interface{}, d *schema.ResourceData, config *tr return v } +func flattenComputeNetworkNetworkId(v interface{}, d *schema.ResourceData, config *transport_tpg.Config) interface{} { + return v +} + func flattenComputeNetworkNumericId(v interface{}, d *schema.ResourceData, config *transport_tpg.Config) interface{} { return v } diff --git a/google/services/compute/resource_compute_network_test.go b/google/services/compute/resource_compute_network_test.go index 54824738a19..2a1aa94452f 100644 --- a/google/services/compute/resource_compute_network_test.go +++ b/google/services/compute/resource_compute_network_test.go @@ -125,6 +125,7 @@ func TestAccComputeNetwork_numericId(t *testing.T) { { Config: testAccComputeNetwork_basic(networkName), Check: resource.ComposeTestCheckFunc( + resource.TestMatchResourceAttr("google_compute_network.bar", "network_id", regexp.MustCompile("^\\d{16,48}$")), resource.TestMatchResourceAttr("google_compute_network.bar", "numeric_id", regexp.MustCompile("^\\d{16,48}$")), resource.TestCheckResourceAttr("google_compute_network.bar", "id", networkId), ), diff --git a/website/docs/d/compute_network.html.markdown b/website/docs/d/compute_network.html.markdown index dfe8b1f4cb3..52de13d65ff 100644 --- a/website/docs/d/compute_network.html.markdown +++ b/website/docs/d/compute_network.html.markdown @@ -36,7 +36,9 @@ In addition to the arguments listed above, the following attributes are exported * `description` - Description of this network. -* `numeric_id` - The numeric unique identifier for the resource. +* `network_id` - The numeric unique identifier for the resource. + +* `numeric_id` - (Deprecated) The numeric unique identifier for the resource. `numeric_id` is deprecated and will be removed in a future major release. Use `network_id` instead. * `gateway_ipv4` - The IP address of the gateway. diff --git a/website/docs/r/compute_network.html.markdown b/website/docs/r/compute_network.html.markdown index 95927b052d3..def0019ee9f 100644 --- a/website/docs/r/compute_network.html.markdown +++ b/website/docs/r/compute_network.html.markdown @@ -209,8 +209,14 @@ In addition to the arguments listed above, the following computed attributes are The gateway address for default routing out of the network. This value is selected by GCP. +* `network_id` - + The unique identifier for the resource. This identifier is defined by the server. + * `numeric_id` - + (Deprecated) The unique identifier for the resource. This identifier is defined by the server. + + ~> **Warning:** `numeric_id` is deprecated and will be removed in a future major release. Use `network_id` instead. * `self_link` - The URI of the created resource.