func getListener(t *testing.T, listenerID string) { listener, err := listeners.Get(base.Client, listenerID).Extract() th.AssertNoErr(t, err) t.Logf("Getting Listener, ID [%s]: ", listener.ID) }
func waitForListenerDelete(networkingClient *gophercloud.ServiceClient, listenerID string) resource.StateRefreshFunc { return func() (interface{}, string, error) { log.Printf("[DEBUG] Attempting to delete OpenStack LBaaSV2 listener %s", listenerID) listener, err := listeners.Get(networkingClient, listenerID).Extract() if err != nil { errCode, ok := err.(*gophercloud.UnexpectedResponseCodeError) if !ok { return listener, "ACTIVE", err } if errCode.Actual == 404 { log.Printf("[DEBUG] Successfully deleted OpenStack LBaaSV2 listener %s", listenerID) return listener, "DELETED", nil } } log.Printf("[DEBUG] Openstack LBaaSV2 listener: %+v", listener) err = listeners.Delete(networkingClient, listenerID).ExtractErr() if err != nil { errCode, ok := err.(*gophercloud.UnexpectedResponseCodeError) if !ok { return listener, "ACTIVE", err } if errCode.Actual == 404 { log.Printf("[DEBUG] Successfully deleted OpenStack LBaaSV2 listener %s", listenerID) return listener, "DELETED", nil } } log.Printf("[DEBUG] OpenStack LBaaSV2 listener %s still active.", listenerID) return listener, "ACTIVE", nil } }
func resourceListenerV2Read(d *schema.ResourceData, meta interface{}) error { config := meta.(*Config) networkingClient, err := config.networkingV2Client(d.Get("region").(string)) if err != nil { return fmt.Errorf("Error creating OpenStack networking client: %s", err) } listener, err := listeners.Get(networkingClient, d.Id()).Extract() if err != nil { return CheckDeleted(d, err, "LBV2 listener") } log.Printf("[DEBUG] Retreived OpenStack LBaaSV2 listener %s: %+v", d.Id(), listener) d.Set("id", listener.ID) d.Set("name", listener.Name) d.Set("protocol", listener.Protocol) d.Set("tenant_id", listener.TenantID) d.Set("description", listener.Description) d.Set("protocol_port", listener.ProtocolPort) d.Set("admin_state_up", listener.AdminStateUp) d.Set("default_pool_id", listener.DefaultPoolID) d.Set("connection_limit", listener.ConnLimit) d.Set("sni_container_refs", listener.SniContainerRefs) d.Set("default_tls_container_ref", listener.DefaultTlsContainerRef) return nil }
func testAccCheckLBV2ListenerExists(t *testing.T, n string, listener *listeners.Listener) 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("(testAccCheckLBV2ListenerExists) Error creating OpenStack networking client: %s", err) } found, err := listeners.Get(networkingClient, rs.Primary.ID).Extract() if err != nil { return err } if found.ID != rs.Primary.ID { return fmt.Errorf("Member not found") } *listener = *found return nil } }
func waitForListenerActive(networkingClient *gophercloud.ServiceClient, listenerID string) resource.StateRefreshFunc { return func() (interface{}, string, error) { listener, err := listeners.Get(networkingClient, listenerID).Extract() if err != nil { return nil, "", err } // The listener resource has no Status attribute, so a successful Get is the best we can do log.Printf("[DEBUG] OpenStack LBaaSV2 listener: %+v", listener) return listener, "ACTIVE", nil } }
func testAccCheckLBV2ListenerDestroy(s *terraform.State) error { config := testAccProvider.Meta().(*Config) networkingClient, err := config.networkingV2Client(OS_REGION_NAME) if err != nil { return fmt.Errorf("(testAccCheckLBV2ListenerDestroy) Error creating OpenStack networking client: %s", err) } for _, rs := range s.RootModule().Resources { if rs.Type != "openstack_lb_listener_v2" { continue } _, err := listeners.Get(networkingClient, rs.Primary.ID).Extract() if err == nil { return fmt.Errorf("Listener still exists: %s", rs.Primary.ID) } } return nil }