From b9eaa23f600325b0dde779a9cda127069ca8a76d Mon Sep 17 00:00:00 2001 From: Gavin Williams Date: Tue, 9 Aug 2016 16:31:22 +0100 Subject: [PATCH] Add support for updating the External Gateway assigned to a Neutron router. Added a simple acceptance test, but doesn't work. --- ...resource_openstack_networking_router_v2.go | 9 ++++++ ...rce_openstack_networking_router_v2_test.go | 32 +++++++++++++++++++ 2 files changed, 41 insertions(+) diff --git a/builtin/providers/openstack/resource_openstack_networking_router_v2.go b/builtin/providers/openstack/resource_openstack_networking_router_v2.go index c6e4982ae1..e79c6f1ca5 100644 --- a/builtin/providers/openstack/resource_openstack_networking_router_v2.go +++ b/builtin/providers/openstack/resource_openstack_networking_router_v2.go @@ -213,6 +213,15 @@ func resourceNetworkingRouterV2Update(d *schema.ResourceData, meta interface{}) asu := d.Get("admin_state_up").(bool) updateOpts.AdminStateUp = &asu } + if d.HasChange("external_gateway") { + externalGateway := d.Get("external_gateway").(string) + if externalGateway != "" { + gatewayInfo := routers.GatewayInfo{ + NetworkID: externalGateway, + } + updateOpts.GatewayInfo = &gatewayInfo + } + } log.Printf("[DEBUG] Updating Router %s with options: %+v", d.Id(), updateOpts) diff --git a/builtin/providers/openstack/resource_openstack_networking_router_v2_test.go b/builtin/providers/openstack/resource_openstack_networking_router_v2_test.go index fd0ff0cc79..f6241c34f7 100644 --- a/builtin/providers/openstack/resource_openstack_networking_router_v2_test.go +++ b/builtin/providers/openstack/resource_openstack_networking_router_v2_test.go @@ -34,6 +34,30 @@ func TestAccNetworkingV2Router_basic(t *testing.T) { }) } +func TestAccNetworkingV2Router_update_external_gw(t *testing.T) { + var router routers.Router + + resource.Test(t, resource.TestCase{ + PreCheck: func() { testAccPreCheck(t) }, + Providers: testAccProviders, + CheckDestroy: testAccCheckNetworkingV2RouterDestroy, + Steps: []resource.TestStep{ + resource.TestStep{ + Config: testAccNetworkingV2Router_basic, + Check: resource.ComposeTestCheckFunc( + testAccCheckNetworkingV2RouterExists(t, "openstack_networking_router_v2.foo", &router), + ), + }, + resource.TestStep{ + Config: testAccNetworkingV2Router_update_external_gw, + Check: resource.ComposeTestCheckFunc( + resource.TestCheckResourceAttr("openstack_networking_router_v2.foo", "external_gateway", "d730db50-0e0c-4790-9972-1f6e2b8c4915"), + ), + }, + }, + }) +} + func testAccCheckNetworkingV2RouterDestroy(s *terraform.State) error { config := testAccProvider.Meta().(*Config) networkingClient, err := config.networkingV2Client(OS_REGION_NAME) @@ -100,3 +124,11 @@ var testAccNetworkingV2Router_update = fmt.Sprintf(` admin_state_up = "true" distributed = "false" }`) + +var testAccNetworkingV2Router_update_external_gw = fmt.Sprintf(` + resource "openstack_networking_router_v2" "foo" { + name = "router" + admin_state_up = "true" + distributed = "false" + external_gateway = "d730db50-0e0c-4790-9972-1f6e2b8c4915" + }`)