Skip to content

Commit

Permalink
update network peering custom routes (#4138) (#2633)
Browse files Browse the repository at this point in the history
Co-authored-by: Cameron Thornton <camthornton@google.com>
Co-authored-by: angie pinilla <angelinepinilla@gmail.com>

Co-authored-by: angie pinilla <angelinepinilla@gmail.com>
Signed-off-by: Modular Magician <magic-modules@google.com>

Co-authored-by: angie pinilla <angelinepinilla@gmail.com>
  • Loading branch information
modular-magician and anGie44 authored Oct 23, 2020
1 parent b77f48f commit 989c65b
Show file tree
Hide file tree
Showing 3 changed files with 106 additions and 2 deletions.
3 changes: 3 additions & 0 deletions .changelog/4138.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
```release-note:enhancement
compute: added support for non-destructive updates to `export_custom_routes` and `import_custom_routes` for `google_compute_network_peering`
```
44 changes: 42 additions & 2 deletions google-beta/resource_compute_network_peering.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,13 +18,15 @@ func resourceComputeNetworkPeering() *schema.Resource {
return &schema.Resource{
Create: resourceComputeNetworkPeeringCreate,
Read: resourceComputeNetworkPeeringRead,
Update: resourceComputeNetworkPeeringUpdate,
Delete: resourceComputeNetworkPeeringDelete,
Importer: &schema.ResourceImporter{
State: resourceComputeNetworkPeeringImport,
},

Timeouts: &schema.ResourceTimeout{
Create: schema.DefaultTimeout(4 * time.Minute),
Update: schema.DefaultTimeout(4 * time.Minute),
Delete: schema.DefaultTimeout(4 * time.Minute),
},

Expand Down Expand Up @@ -57,15 +59,13 @@ func resourceComputeNetworkPeering() *schema.Resource {

"export_custom_routes": {
Type: schema.TypeBool,
ForceNew: true,
Optional: true,
Default: false,
Description: `Whether to export the custom routes to the peer network. Defaults to false.`,
},

"import_custom_routes": {
Type: schema.TypeBool,
ForceNew: true,
Optional: true,
Default: false,
Description: `Whether to export the custom routes from the peer network. Defaults to false.`,
Expand Down Expand Up @@ -194,6 +194,46 @@ func resourceComputeNetworkPeeringRead(d *schema.ResourceData, meta interface{})
return nil
}

func resourceComputeNetworkPeeringUpdate(d *schema.ResourceData, meta interface{}) error {
config := meta.(*Config)
userAgent, err := generateUserAgentString(d, config.userAgent)
if err != nil {
return err
}

networkFieldValue, err := ParseNetworkFieldValue(d.Get("network").(string), d, config)
if err != nil {
return err
}
peerNetworkFieldValue, err := ParseNetworkFieldValue(d.Get("peer_network").(string), d, config)
if err != nil {
return err
}

request := &compute.NetworksUpdatePeeringRequest{}
request.NetworkPeering = expandNetworkPeering(d)

// Only one peering operation at a time can be performed for a given network.
// Lock on both networks, sorted so we don't deadlock for A <--> B peering pairs.
peeringLockNames := sortedNetworkPeeringMutexKeys(networkFieldValue, peerNetworkFieldValue)
for _, kn := range peeringLockNames {
mutexKV.Lock(kn)
defer mutexKV.Unlock(kn)
}

updateOp, err := config.NewComputeClient(userAgent).Networks.UpdatePeering(networkFieldValue.Project, networkFieldValue.Name, request).Do()
if err != nil {
return fmt.Errorf("Error updating network peering: %s", err)
}

err = computeOperationWaitTime(config, updateOp, networkFieldValue.Project, "Updating Network Peering", userAgent, d.Timeout(schema.TimeoutUpdate))
if err != nil {
return err
}

return resourceComputeNetworkPeeringRead(d, meta)
}

func resourceComputeNetworkPeeringDelete(d *schema.ResourceData, meta interface{}) error {
config := meta.(*Config)
userAgent, err := generateUserAgentString(d, config.userAgent)
Expand Down
61 changes: 61 additions & 0 deletions google-beta/resource_compute_network_peering_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,41 @@ func TestAccComputeNetworkPeering_subnetRoutes(t *testing.T) {
})
}

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

primaryNetworkName := fmt.Sprintf("network-test-1-%d", randInt(t))
peeringName := fmt.Sprintf("peering-test-%d", randInt(t))
importId := fmt.Sprintf("%s/%s/%s", getTestProjectFromEnv(), primaryNetworkName, peeringName)
suffix := randString(t, 10)

vcrTest(t, resource.TestCase{
PreCheck: func() { testAccPreCheck(t) },
Providers: testAccProviders,
CheckDestroy: testAccComputeNetworkPeeringDestroyProducer(t),
Steps: []resource.TestStep{
{
Config: testAccComputeNetworkPeeringDefaultCustomRoutes(primaryNetworkName, peeringName, suffix),
},
{
ResourceName: "google_compute_network_peering.bar",
ImportState: true,
ImportStateVerify: true,
ImportStateId: importId,
},
{
Config: testAccComputeNetworkPeering_basic(primaryNetworkName, peeringName, suffix),
},
{
ResourceName: "google_compute_network_peering.bar",
ImportState: true,
ImportStateVerify: true,
ImportStateId: importId,
},
},
})
}

func testAccComputeNetworkPeeringDestroyProducer(t *testing.T) func(s *terraform.State) error {
return func(s *terraform.State) error {
config := googleProviderConfig(t)
Expand Down Expand Up @@ -128,3 +163,29 @@ resource "google_compute_network_peering" "bar" {
}
`, primaryNetworkName, suffix, peeringName)
}

func testAccComputeNetworkPeeringDefaultCustomRoutes(primaryNetworkName, peeringName, suffix string) string {
s := `
resource "google_compute_network" "network1" {
name = "%s"
auto_create_subnetworks = false
}
resource "google_compute_network_peering" "foo" {
name = "%s"
network = google_compute_network.network1.self_link
peer_network = google_compute_network.network2.self_link
}
resource "google_compute_network" "network2" {
name = "network-test-2-%s"
auto_create_subnetworks = false
}
resource "google_compute_network_peering" "bar" {
network = google_compute_network.network2.self_link
peer_network = google_compute_network.network1.self_link
name = "peering-test-2-%s"
}`
return fmt.Sprintf(s, primaryNetworkName, peeringName, suffix, suffix)
}

0 comments on commit 989c65b

Please sign in to comment.