func listSecGroups(t *testing.T) { err := rsGroups.List(Client, osGroups.ListOpts{}).EachPage(func(page pagination.Page) (bool, error) { list, err := osGroups.ExtractGroups(page) if err != nil { t.Errorf("Failed to extract secgroups: %v", err) return false, err } for _, sg := range list { t.Logf("Listing security group: ID [%s] Name [%s]", sg.ID, sg.Name) } return true, nil }) th.AssertNoErr(t, err) }
func (command *commandList) Execute(resource *handler.Resource) { opts := resource.Params.(*paramsList).opts allPages := resource.Params.(*paramsList).allPages pager := securityGroups.List(command.Ctx.ServiceClient, *opts) if allPages { pages, err := pager.AllPages() if err != nil { resource.Err = err return } info, err := osSecurityGroups.ExtractGroups(pages) if err != nil { resource.Err = err return } result := make([]map[string]interface{}, len(info)) for j, subnet := range info { result[j] = securityGroupSingle(&subnet) } resource.Result = result } else { limit := opts.Limit err := pager.EachPage(func(page pagination.Page) (bool, error) { info, err := osSecurityGroups.ExtractGroups(page) if err != nil { return false, err } result := make([]map[string]interface{}, len(info)) for j, subnet := range info { result[j] = securityGroupSingle(&subnet) } resource.Result = result if len(info) >= limit { return false, nil } limit -= len(info) command.Ctx.WaitGroup.Add(1) command.Ctx.Results <- resource return true, nil }) if err != nil { resource.Err = err return } } }