// CreateMember will create a member with a random name, port, address, and // weight. An error will be returned if the member could not be created. func CreateMember(t *testing.T, client *gophercloud.ServiceClient, lb *loadbalancers.LoadBalancer, pool *pools.Pool, subnetID, subnetCIDR string) (*pools.Member, error) { memberName := tools.RandomString("TESTACCT-", 8) memberPort := tools.RandomInt(100, 1000) memberWeight := tools.RandomInt(1, 10) cidrParts := strings.Split(subnetCIDR, "/") subnetParts := strings.Split(cidrParts[0], ".") memberAddress := fmt.Sprintf("%s.%s.%s.%d", subnetParts[0], subnetParts[1], subnetParts[2], tools.RandomInt(10, 100)) t.Logf("Attempting to create member %s", memberName) createOpts := pools.CreateMemberOpts{ Name: memberName, ProtocolPort: memberPort, Weight: memberWeight, Address: memberAddress, SubnetID: subnetID, } t.Logf("Member create opts: %#v", createOpts) member, err := pools.CreateMember(client, pool.ID, createOpts).Extract() if err != nil { return member, err } t.Logf("Successfully created member %s", memberName) if err := WaitForLoadBalancerState(client, lb.ID, "ACTIVE", loadbalancerActiveTimeoutSeconds); err != nil { return member, fmt.Errorf("Timed out waiting for loadbalancer to become active") } return member, nil }
func TestRequiredMemberCreateOpts(t *testing.T) { res := pools.CreateMember(fake.ServiceClient(), "", pools.CreateMemberOpts{}) if res.Err == nil { t.Fatalf("Expected error, got none") } res = pools.CreateMember(fake.ServiceClient(), "", pools.CreateMemberOpts{Address: "1.2.3.4", ProtocolPort: 80}) if res.Err == nil { t.Fatalf("Expected error, but got none") } res = pools.CreateMember(fake.ServiceClient(), "332abe93-f488-41ba-870b-2ac66be7f853", pools.CreateMemberOpts{ProtocolPort: 80}) if res.Err == nil { t.Fatalf("Expected error, but got none") } res = pools.CreateMember(fake.ServiceClient(), "332abe93-f488-41ba-870b-2ac66be7f853", pools.CreateMemberOpts{Address: "1.2.3.4"}) if res.Err == nil { t.Fatalf("Expected error, but got none") } }
func resourceMemberV2Create(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) } adminStateUp := d.Get("admin_state_up").(bool) createOpts := pools.CreateMemberOpts{ Name: d.Get("name").(string), TenantID: d.Get("tenant_id").(string), Address: d.Get("address").(string), ProtocolPort: d.Get("protocol_port").(int), Weight: d.Get("weight").(int), AdminStateUp: &adminStateUp, } // Must omit if not set if v, ok := d.GetOk("subnet_id"); ok { createOpts.SubnetID = v.(string) } poolID := d.Get("pool_id").(string) log.Printf("[DEBUG] Create Options: %#v", createOpts) member, err := pools.CreateMember(networkingClient, poolID, createOpts).Extract() if err != nil { return fmt.Errorf("Error creating OpenStack LBaaSV2 member: %s", err) } log.Printf("[INFO] member ID: %s", member.ID) log.Printf("[DEBUG] Waiting for Openstack LBaaSV2 member (%s) to become available.", member.ID) stateConf := &resource.StateChangeConf{ Pending: []string{"PENDING_CREATE"}, Target: []string{"ACTIVE"}, Refresh: waitForMemberActive(networkingClient, poolID, member.ID), Timeout: 2 * time.Minute, Delay: 5 * time.Second, MinTimeout: 3 * time.Second, } _, err = stateConf.WaitForState() if err != nil { return err } d.SetId(member.ID) return resourceMemberV2Read(d, meta) }
func TestCreateMember(t *testing.T) { th.SetupHTTP() defer th.TeardownHTTP() HandleMemberCreationSuccessfully(t, SingleMemberBody) actual, err := pools.CreateMember(fake.ServiceClient(), "332abe93-f488-41ba-870b-2ac66be7f853", pools.CreateMemberOpts{ Name: "db", SubnetID: "1981f108-3c48-48d2-b908-30f7d28532c9", TenantID: "2ffc6e22aae24e4795f87155d24c896f", Address: "10.0.2.11", ProtocolPort: 80, Weight: 10, }).Extract() th.AssertNoErr(t, err) th.CheckDeepEquals(t, MemberDb, *actual) }
func resourceMemberV2Create(d *schema.ResourceData, meta interface{}) error { config := meta.(*Config) networkingClient, err := config.networkingV2Client(GetRegion(d)) if err != nil { return fmt.Errorf("Error creating OpenStack networking client: %s", err) } adminStateUp := d.Get("admin_state_up").(bool) createOpts := pools.CreateMemberOpts{ Name: d.Get("name").(string), TenantID: d.Get("tenant_id").(string), Address: d.Get("address").(string), ProtocolPort: d.Get("protocol_port").(int), Weight: d.Get("weight").(int), AdminStateUp: &adminStateUp, } // Must omit if not set if v, ok := d.GetOk("subnet_id"); ok { createOpts.SubnetID = v.(string) } poolID := d.Get("pool_id").(string) log.Printf("[DEBUG] Create Options: %#v", createOpts) var member *pools.Member err = resource.Retry(10*time.Minute, func() *resource.RetryError { var err error log.Printf("[DEBUG] Attempting to create LBaaSV2 member") member, err = pools.CreateMember(networkingClient, poolID, createOpts).Extract() if err != nil { if errCode, ok := err.(gophercloud.ErrUnexpectedResponseCode); ok { if errCode.Actual == 409 || errCode.Actual == 500 { log.Printf("[DEBUG] OpenStack LBaaSV2 member is still creating.") return resource.RetryableError(err) } } return resource.NonRetryableError(err) } return nil }) if err != nil { return fmt.Errorf("Error creating OpenStack LBaaSV2 member: %s", err) } log.Printf("[INFO] member ID: %s", member.ID) log.Printf("[DEBUG] Waiting for Openstack LBaaSV2 member (%s) to become available.", member.ID) stateConf := &resource.StateChangeConf{ Pending: []string{"PENDING_CREATE"}, Target: []string{"ACTIVE"}, Refresh: waitForMemberActive(networkingClient, poolID, member.ID), Timeout: 2 * time.Minute, Delay: 5 * time.Second, MinTimeout: 3 * time.Second, } _, err = stateConf.WaitForState() if err != nil { return err } d.SetId(member.ID) return resourceMemberV2Read(d, meta) }