mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-25 04:33:26 +00:00
Merge pull request #50500 from shiywang/sortby
Automatic merge from submit-queue (batch tested with PRs 50302, 50573, 50500, 50633, 50617) add cmd-test for sort-by command this follow up : https://github.com/kubernetes/kubernetes/pull/48659 /assign @pwittrock as your suggestion, cmd-test added, ptal ```release-note NONE ```
This commit is contained in:
commit
a12cf94432
@ -250,6 +250,17 @@ kube::test::describe_resource_events_assert() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Compare sort-by resource name output with expected order specify in the last parameter
|
||||||
|
kube::test::if_sort_by_has_correct_order() {
|
||||||
|
local array=($(echo "$1" |awk '{if(NR!=1) print $1}'))
|
||||||
|
local var
|
||||||
|
for i in "${array[@]}"; do
|
||||||
|
var+="$i:"
|
||||||
|
done
|
||||||
|
|
||||||
|
kube::test::if_has_string "$var" "${@:$#}"
|
||||||
|
}
|
||||||
|
|
||||||
kube::test::if_has_string() {
|
kube::test::if_has_string() {
|
||||||
local message=$1
|
local message=$1
|
||||||
local match=$2
|
local match=$2
|
||||||
|
@ -3940,6 +3940,38 @@ run_kubectl_sort_by_tests() {
|
|||||||
# Post-condition: valid-pod doesn't exist
|
# Post-condition: valid-pod doesn't exist
|
||||||
kube::test::get_object_assert pods "{{range.items}}{{$id_field}}:{{end}}" ''
|
kube::test::get_object_assert pods "{{range.items}}{{$id_field}}:{{end}}" ''
|
||||||
|
|
||||||
|
### sort-by should works by sorting by name
|
||||||
|
# Create three PODs
|
||||||
|
# Pre-condition: no POD exists
|
||||||
|
kube::test::get_object_assert pods "{{range.items}}{{$id_field}}:{{end}}" ''
|
||||||
|
# Command
|
||||||
|
kubectl create "${kube_flags[@]}" -f hack/testdata/sorted-pods/sorted-pod1.yaml
|
||||||
|
# Post-condition: sorted-pod1 is created
|
||||||
|
kube::test::get_object_assert pods "{{range.items}}{{$id_field}}:{{end}}" 'sorted-pod1:'
|
||||||
|
# Command
|
||||||
|
kubectl create "${kube_flags[@]}" -f hack/testdata/sorted-pods/sorted-pod2.yaml
|
||||||
|
# Post-condition: sorted-pod1 is created
|
||||||
|
kube::test::get_object_assert pods "{{range.items}}{{$id_field}}:{{end}}" 'sorted-pod1:sorted-pod2:'
|
||||||
|
# Command
|
||||||
|
kubectl create "${kube_flags[@]}" -f hack/testdata/sorted-pods/sorted-pod3.yaml
|
||||||
|
# Post-condition: sorted-pod1 is created
|
||||||
|
kube::test::get_object_assert pods "{{range.items}}{{$id_field}}:{{end}}" 'sorted-pod1:sorted-pod2:sorted-pod3:'
|
||||||
|
|
||||||
|
# Check output of sort-by '{metadata.name}'
|
||||||
|
output_message=$(kubectl get pods --sort-by="{metadata.name}")
|
||||||
|
kube::test::if_sort_by_has_correct_order "${output_message}" "sorted-pod1:sorted-pod2:sorted-pod3:"
|
||||||
|
|
||||||
|
# Check output of sort-by '{metadata.labels.name}'
|
||||||
|
output_message=$(kubectl get pods --sort-by="{metadata.labels.name}")
|
||||||
|
kube::test::if_sort_by_has_correct_order "${output_message}" "sorted-pod3:sorted-pod2:sorted-pod1:"
|
||||||
|
|
||||||
|
### Clean up
|
||||||
|
# Pre-condition: valid-pod exists
|
||||||
|
kube::test::get_object_assert pods "{{range.items}}{{$id_field}}:{{end}}" 'sorted-pod1:sorted-pod2:sorted-pod3:'
|
||||||
|
# Command
|
||||||
|
kubectl delete "${kube_flags[@]}" pod --grace-period=0 --force --all
|
||||||
|
# Post-condition: valid-pod doesn't exist
|
||||||
|
kube::test::get_object_assert pods "{{range.items}}{{$id_field}}:{{end}}" ''
|
||||||
|
|
||||||
set +o nounset
|
set +o nounset
|
||||||
set +o errexit
|
set +o errexit
|
||||||
|
10
hack/testdata/sorted-pods/sorted-pod1.yaml
vendored
Normal file
10
hack/testdata/sorted-pods/sorted-pod1.yaml
vendored
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: Pod
|
||||||
|
metadata:
|
||||||
|
name: sorted-pod1
|
||||||
|
labels:
|
||||||
|
name: sorted-pod3-label
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: kubernetes-pause
|
||||||
|
image: gcr.io/google-containers/pause:2.0
|
10
hack/testdata/sorted-pods/sorted-pod2.yaml
vendored
Normal file
10
hack/testdata/sorted-pods/sorted-pod2.yaml
vendored
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: Pod
|
||||||
|
metadata:
|
||||||
|
name: sorted-pod2
|
||||||
|
labels:
|
||||||
|
name: sorted-pod2-label
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: kubernetes-pause
|
||||||
|
image: gcr.io/google-containers/pause:2.0
|
10
hack/testdata/sorted-pods/sorted-pod3.yaml
vendored
Normal file
10
hack/testdata/sorted-pods/sorted-pod3.yaml
vendored
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: Pod
|
||||||
|
metadata:
|
||||||
|
name: sorted-pod3
|
||||||
|
labels:
|
||||||
|
name: sorted-pod1-label
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: kubernetes-pause
|
||||||
|
image: gcr.io/google-containers/pause:2.0
|
Loading…
Reference in New Issue
Block a user