Merge pull request #4438 from ks-ci-bot/cherry-pick-4434-to-release-3.2

[release-3.2] Support query pods by status
This commit is contained in:
KubeSphere CI Bot
2021-11-12 10:45:34 +08:00
committed by GitHub
2 changed files with 42 additions and 9 deletions

View File

@@ -28,9 +28,10 @@ import (
) )
const ( const (
filedNameName = "nodeName" fieldNodeName = "nodeName"
filedPVCName = "pvcName" fieldPVCName = "pvcName"
filedServiceName = "serviceName" fieldServiceName = "serviceName"
fieldStatus = "status"
) )
type podsGetter struct { type podsGetter struct {
@@ -82,12 +83,14 @@ func (p *podsGetter) filter(object runtime.Object, filter query.Filter) bool {
return false return false
} }
switch filter.Field { switch filter.Field {
case filedNameName: case fieldNodeName:
return pod.Spec.NodeName == string(filter.Value) return pod.Spec.NodeName == string(filter.Value)
case filedPVCName: case fieldPVCName:
return p.podBindPVC(pod, string(filter.Value)) return p.podBindPVC(pod, string(filter.Value))
case filedServiceName: case fieldServiceName:
return p.podBelongToService(pod, string(filter.Value)) return p.podBelongToService(pod, string(filter.Value))
case fieldStatus:
return string(pod.Status.Phase) == string(filter.Value)
default: default:
return v1alpha3.DefaultObjectMetaFilter(pod.ObjectMeta, filter) return v1alpha3.DefaultObjectMetaFilter(pod.ObjectMeta, filter)
} }

View File

@@ -51,7 +51,7 @@ func TestListPods(t *testing.T) {
Filters: map[query.Field]query.Value{query.FieldNamespace: query.Value("default")}, Filters: map[query.Field]query.Value{query.FieldNamespace: query.Value("default")},
}, },
&api.ListResult{ &api.ListResult{
Items: []interface{}{foo4, foo3, foo2, foo1}, Items: []interface{}{foo5, foo4, foo3, foo2, foo1},
TotalItems: len(pods), TotalItems: len(pods),
}, },
nil, nil,
@@ -68,7 +68,7 @@ func TestListPods(t *testing.T) {
Ascending: false, Ascending: false,
Filters: map[query.Field]query.Value{ Filters: map[query.Field]query.Value{
query.FieldNamespace: query.Value("default"), query.FieldNamespace: query.Value("default"),
filedPVCName: query.Value(foo4.Spec.Volumes[0].PersistentVolumeClaim.ClaimName), fieldPVCName: query.Value(foo4.Spec.Volumes[0].PersistentVolumeClaim.ClaimName),
}, },
}, },
&api.ListResult{ &api.ListResult{
@@ -77,6 +77,27 @@ func TestListPods(t *testing.T) {
}, },
nil, nil,
}, },
{
"test status filter",
"default",
&query.Query{
Pagination: &query.Pagination{
Limit: 10,
Offset: 0,
},
SortBy: query.FieldName,
Ascending: false,
Filters: map[query.Field]query.Value{
query.FieldNamespace: query.Value("default"),
fieldStatus: query.Value(corev1.PodRunning),
},
},
&api.ListResult{
Items: []interface{}{foo5},
TotalItems: 1,
},
nil,
},
} }
getter := prepare() getter := prepare()
@@ -133,7 +154,16 @@ var (
}, },
}, },
} }
pods = []interface{}{foo1, foo2, foo3, foo4} foo5 = &corev1.Pod{
ObjectMeta: metav1.ObjectMeta{
Name: "foo5",
Namespace: "default",
},
Status: corev1.PodStatus{
Phase: corev1.PodRunning,
},
}
pods = []interface{}{foo1, foo2, foo3, foo4, foo5}
) )
func prepare() v1alpha3.Interface { func prepare() v1alpha3.Interface {