package openstack import ( "fmt" "testing" "github.com/gophercloud/gophercloud/openstack/networking/v2/extensions/lbaas_v2/pools" "github.com/hashicorp/terraform/helper/resource" "github.com/hashicorp/terraform/terraform" ) func TestAccLBV2Member_basic(t *testing.T) { var member pools.Member resource.Test(t, resource.TestCase{ PreCheck: func() { testAccPreCheck(t) }, Providers: testAccProviders, CheckDestroy: testAccCheckLBV2MemberDestroy, Steps: []resource.TestStep{ resource.TestStep{ Config: TestAccLBV2MemberConfig_basic, Check: resource.ComposeTestCheckFunc( testAccCheckLBV2MemberExists("openstack_lb_member_v2.member_1", &member), ), }, resource.TestStep{ Config: TestAccLBV2MemberConfig_update, Check: resource.ComposeTestCheckFunc( resource.TestCheckResourceAttr("openstack_lb_member_v2.member_1", "weight", "10"), ), }, }, }) } func TestAccLBV2Member_timeout(t *testing.T) { var member pools.Member resource.Test(t, resource.TestCase{ PreCheck: func() { testAccPreCheck(t) }, Providers: testAccProviders, CheckDestroy: testAccCheckLBV2MemberDestroy, Steps: []resource.TestStep{ resource.TestStep{ Config: TestAccLBV2MemberConfig_timeout, Check: resource.ComposeTestCheckFunc( testAccCheckLBV2MemberExists("openstack_lb_member_v2.member_1", &member), ), }, }, }) } func testAccCheckLBV2MemberDestroy(s *terraform.State) error { config := testAccProvider.Meta().(*Config) networkingClient, err := config.networkingV2Client(OS_REGION_NAME) if err != nil { return fmt.Errorf("Error creating OpenStack networking client: %s", err) } for _, rs := range s.RootModule().Resources { if rs.Type != "openstack_lb_member_v2" { continue } poolId := rs.Primary.Attributes["pool_id"] _, err := pools.GetMember(networkingClient, poolId, rs.Primary.ID).Extract() if err == nil { return fmt.Errorf("Member still exists: %s", rs.Primary.ID) } } return nil } func testAccCheckLBV2MemberExists(n string, member *pools.Member) resource.TestCheckFunc { return func(s *terraform.State) error { rs, ok := s.RootModule().Resources[n] if !ok { return fmt.Errorf("Not found: %s", n) } if rs.Primary.ID == "" { return fmt.Errorf("No ID is set") } config := testAccProvider.Meta().(*Config) networkingClient, err := config.networkingV2Client(OS_REGION_NAME) if err != nil { return fmt.Errorf("Error creating OpenStack networking client: %s", err) } poolId := rs.Primary.Attributes["pool_id"] found, err := pools.GetMember(networkingClient, poolId, rs.Primary.ID).Extract() if err != nil { return err } if found.ID != rs.Primary.ID { return fmt.Errorf("Member not found") } *member = *found return nil } } const TestAccLBV2MemberConfig_basic = ` resource "openstack_networking_network_v2" "network_1" { name = "network_1" admin_state_up = "true" } resource "openstack_networking_subnet_v2" "subnet_1" { name = "subnet_1" network_id = "${openstack_networking_network_v2.network_1.id}" cidr = "192.168.199.0/24" ip_version = 4 } resource "openstack_lb_loadbalancer_v2" "loadbalancer_1" { name = "loadbalancer_1" vip_subnet_id = "${openstack_networking_subnet_v2.subnet_1.id}" } resource "openstack_lb_listener_v2" "listener_1" { name = "listener_1" protocol = "HTTP" protocol_port = 8080 loadbalancer_id = "${openstack_lb_loadbalancer_v2.loadbalancer_1.id}" } resource "openstack_lb_pool_v2" "pool_1" { name = "pool_1" protocol = "HTTP" lb_method = "ROUND_ROBIN" listener_id = "${openstack_lb_listener_v2.listener_1.id}" } resource "openstack_lb_member_v2" "member_1" { address = "192.168.199.10" protocol_port = 8080 pool_id = "${openstack_lb_pool_v2.pool_1.id}" subnet_id = "${openstack_networking_subnet_v2.subnet_1.id}" } ` const TestAccLBV2MemberConfig_update = ` resource "openstack_networking_network_v2" "network_1" { name = "network_1" admin_state_up = "true" } resource "openstack_networking_subnet_v2" "subnet_1" { name = "subnet_1" cidr = "192.168.199.0/24" ip_version = 4 network_id = "${openstack_networking_network_v2.network_1.id}" } resource "openstack_lb_loadbalancer_v2" "loadbalancer_1" { name = "loadbalancer_1" vip_subnet_id = "${openstack_networking_subnet_v2.subnet_1.id}" } resource "openstack_lb_listener_v2" "listener_1" { name = "listener_1" protocol = "HTTP" protocol_port = 8080 loadbalancer_id = "${openstack_lb_loadbalancer_v2.loadbalancer_1.id}" } resource "openstack_lb_pool_v2" "pool_1" { name = "pool_1" protocol = "HTTP" lb_method = "ROUND_ROBIN" listener_id = "${openstack_lb_listener_v2.listener_1.id}" } resource "openstack_lb_member_v2" "member_1" { address = "192.168.199.10" protocol_port = 8080 weight = 10 admin_state_up = "true" pool_id = "${openstack_lb_pool_v2.pool_1.id}" subnet_id = "${openstack_networking_subnet_v2.subnet_1.id}" } ` const TestAccLBV2MemberConfig_timeout = ` resource "openstack_networking_network_v2" "network_1" { name = "network_1" admin_state_up = "true" } resource "openstack_networking_subnet_v2" "subnet_1" { name = "subnet_1" network_id = "${openstack_networking_network_v2.network_1.id}" cidr = "192.168.199.0/24" ip_version = 4 } resource "openstack_lb_loadbalancer_v2" "loadbalancer_1" { name = "loadbalancer_1" vip_subnet_id = "${openstack_networking_subnet_v2.subnet_1.id}" } resource "openstack_lb_listener_v2" "listener_1" { name = "listener_1" protocol = "HTTP" protocol_port = 8080 loadbalancer_id = "${openstack_lb_loadbalancer_v2.loadbalancer_1.id}" } resource "openstack_lb_pool_v2" "pool_1" { name = "pool_1" protocol = "HTTP" lb_method = "ROUND_ROBIN" listener_id = "${openstack_lb_listener_v2.listener_1.id}" } resource "openstack_lb_member_v2" "member_1" { address = "192.168.199.10" protocol_port = 8080 pool_id = "${openstack_lb_pool_v2.pool_1.id}" subnet_id = "${openstack_networking_subnet_v2.subnet_1.id}" timeouts { create = "5m" delete = "5m" } } `