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:
@@ -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)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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 {
|
||||||
|
|||||||
Reference in New Issue
Block a user