in src/app/backend/resource/deployment/newreplicasets.go [31:85]
func GetDeploymentNewReplicaSet(client client.Interface, dsQuery *dataselect.DataSelectQuery,
namespace string, deploymentName string) (*replicaset.ReplicaSet, error) {
newReplicaSet := &replicaset.ReplicaSet{}
deployment, err := client.AppsV1().Deployments(namespace).Get(context.TODO(), deploymentName, metaV1.GetOptions{})
if err != nil {
return newReplicaSet, err
}
selector, err := metaV1.LabelSelectorAsSelector(deployment.Spec.Selector)
if err != nil {
return newReplicaSet, err
}
options := metaV1.ListOptions{LabelSelector: selector.String()}
channels := &common.ResourceChannels{
ReplicaSetList: common.GetReplicaSetListChannelWithOptions(client,
common.NewSameNamespaceQuery(namespace), options, 1),
PodList: common.GetPodListChannelWithOptions(client,
common.NewSameNamespaceQuery(namespace), options, 1),
EventList: common.GetEventListChannelWithOptions(client,
common.NewSameNamespaceQuery(namespace), options, 1),
}
rawRs := <-channels.ReplicaSetList.List
if err := <-channels.ReplicaSetList.Error; err != nil {
return newReplicaSet, err
}
rawPods := <-channels.PodList.List
if err := <-channels.PodList.Error; err != nil {
return newReplicaSet, err
}
rawEvents := <-channels.EventList.List
err = <-channels.EventList.Error
nonCriticalErrors, criticalError := errors.HandleError(err)
if criticalError != nil {
return newReplicaSet, criticalError
}
rawRepSets := make([]*apps.ReplicaSet, 0)
for i := range rawRs.Items {
rawRepSets = append(rawRepSets, &rawRs.Items[i])
}
newRS := FindNewReplicaSet(deployment, rawRepSets)
if newRS == nil {
return newReplicaSet, err
}
newReplicaSetList := replicaset.ToReplicaSetList([]apps.ReplicaSet{*newRS}, rawPods.Items, rawEvents.Items,
nonCriticalErrors, dsQuery, nil)
return &newReplicaSetList.ReplicaSets[0], nil
}