mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-31 15:25:57 +00:00
Loop three types of files for each "multiple resources" test
This commit is contained in:
parent
7007481f00
commit
b10e86038e
145
hack/test-cmd.sh
145
hack/test-cmd.sh
@ -734,102 +734,57 @@ __EOF__
|
|||||||
kube::log::status "Testing kubectl(${version}:multiple resources)"
|
kube::log::status "Testing kubectl(${version}:multiple resources)"
|
||||||
# TODO: add test for types like ReplicationControllerList, ServiceList
|
# TODO: add test for types like ReplicationControllerList, ServiceList
|
||||||
|
|
||||||
### Create, get, describe, replace, label, annotate, and then delete service nginxsvc and replication controller my-nginx from YAML, separated by ---
|
FILES="hack/testdata/multi-resource-yaml
|
||||||
# Pre-condition: no service (other than default kubernetes services) or replication controller is running
|
hack/testdata/multi-resource-list
|
||||||
kube::test::get_object_assert services "{{range.items}}{{$id_field}}:{{end}}" 'kubernetes:'
|
hack/testdata/multi-resource-json"
|
||||||
kube::test::get_object_assert rc "{{range.items}}{{$id_field}}:{{end}}" ''
|
YAML=".yaml"
|
||||||
# Command
|
JSON=".json"
|
||||||
kubectl create -f examples/https-nginx/nginx-app.yaml "${kube_flags[@]}"
|
for file in $FILES; do
|
||||||
# Post-condition: nginxsvc service is running
|
if [ -f $file$YAML ]
|
||||||
kube::test::get_object_assert services "{{range.items}}{{$id_field}}:{{end}}" 'kubernetes:nginxsvc:'
|
then
|
||||||
# Post-condition: my-nginx rc is running
|
file=$file$YAML
|
||||||
kube::test::get_object_assert rc "{{range.items}}{{$id_field}}:{{end}}" 'my-nginx:'
|
replace_file="${file%.yaml}-modify.yaml"
|
||||||
# Command
|
else
|
||||||
kubectl get -f examples/https-nginx/nginx-app.yaml "${kube_flags[@]}"
|
file=$file$JSON
|
||||||
kubectl describe -f examples/https-nginx/nginx-app.yaml "${kube_flags[@]}"
|
replace_file="${file%.json}-modify.json"
|
||||||
# Command
|
fi
|
||||||
kubectl replace -f hack/testdata/nginx-app-modify.yaml --force "${kube_flags[@]}"
|
|
||||||
# Post-condition: nginxsvc service and mock rc are replaced
|
|
||||||
kube::test::get_object_assert 'services nginxsvc' "{{${labels_field}.status}}" 'replaced'
|
|
||||||
kube::test::get_object_assert 'rc my-nginx' "{{${labels_field}.status}}" 'replaced'
|
|
||||||
# Command
|
|
||||||
kubectl label -f examples/https-nginx/nginx-app.yaml labeled=true "${kube_flags[@]}"
|
|
||||||
# Post-condition: nginxsvc service and my-nginx rc are labeled
|
|
||||||
kube::test::get_object_assert 'services nginxsvc' "{{${labels_field}.labeled}}" 'true'
|
|
||||||
kube::test::get_object_assert 'rc my-nginx' "{{${labels_field}.labeled}}" 'true'
|
|
||||||
# Command
|
|
||||||
kubectl annotate -f examples/https-nginx/nginx-app.yaml annotated=true "${kube_flags[@]}"
|
|
||||||
# Post-condition: nginxsvc service and my-nginx rc are annotated
|
|
||||||
kube::test::get_object_assert 'services nginxsvc' "{{${annotations_field}.annotated}}" 'true'
|
|
||||||
kube::test::get_object_assert 'rc my-nginx' "{{${annotations_field}.annotated}}" 'true'
|
|
||||||
# Cleanup service and rc
|
|
||||||
kubectl delete -f examples/https-nginx/nginx-app.yaml "${kube_flags[@]}"
|
|
||||||
|
|
||||||
### Create, get, describe, replace, label, annotate, and then delete service nginxsvc and replication controller my-nginx from JSON, with a List type
|
### Create, get, describe, replace, label, annotate, and then delete service nginxsvc and replication controller my-nginx from 3 types of files:
|
||||||
# Pre-condition: no service (other than default kubernetes services) or replication controller is running
|
### 1) YAML, separated by ---; 2) JSON, with a List type; 3) JSON, with JSON object concatenation
|
||||||
kube::test::get_object_assert services "{{range.items}}{{$id_field}}:{{end}}" 'kubernetes:'
|
# Pre-condition: no service (other than default kubernetes services) or replication controller is running
|
||||||
kube::test::get_object_assert rc "{{range.items}}{{$id_field}}:{{end}}" ''
|
kube::test::get_object_assert services "{{range.items}}{{$id_field}}:{{end}}" 'kubernetes:'
|
||||||
# Command
|
kube::test::get_object_assert rc "{{range.items}}{{$id_field}}:{{end}}" ''
|
||||||
# TODO: remove --validate=false when PR "Add validate support for list kind #14726" is merged
|
# Command
|
||||||
kubectl create -f hack/testdata/multi-resource-list.json --validate=false "${kube_flags[@]}"
|
# TODO: remove --validate=false when PR "Add validate support for list kind #14726" is merged
|
||||||
# Post-condition: mock service is running
|
kubectl create -f $file --validate=false "${kube_flags[@]}"
|
||||||
kube::test::get_object_assert services "{{range.items}}{{$id_field}}:{{end}}" 'kubernetes:mock:'
|
# Post-condition: mock service is running
|
||||||
# Post-condition: mock rc is running
|
kube::test::get_object_assert services "{{range.items}}{{$id_field}}:{{end}}" 'kubernetes:mock:'
|
||||||
kube::test::get_object_assert rc "{{range.items}}{{$id_field}}:{{end}}" 'mock:'
|
# Post-condition: mock rc is running
|
||||||
# Command
|
kube::test::get_object_assert rc "{{range.items}}{{$id_field}}:{{end}}" 'mock:'
|
||||||
# kubectl create -f hack/testdata/multi-resource.json "${kube_flags[@]}" # test fails here now
|
# Command
|
||||||
# TODO: test get when PR "Fix get with List #14888" is merged
|
# kubectl create -f $file "${kube_flags[@]}" # test fails here now
|
||||||
# kubectl get -f hack/testdata/multi-resource-list.json "${kube_flags[@]}"
|
# TODO: test get when PR "Fix get with List #14888" is merged
|
||||||
kubectl describe -f hack/testdata/multi-resource-list.json "${kube_flags[@]}"
|
# kubectl get -f $file "${kube_flags[@]}"
|
||||||
# Command
|
kubectl describe -f $file "${kube_flags[@]}"
|
||||||
# TODO: remove --validate=false when PR "Add validate support for list kind #14726" is merged
|
# Command
|
||||||
kubectl replace -f hack/testdata/multi-resource-list-modify.json --force --validate=false "${kube_flags[@]}"
|
# TODO: remove --validate=false when PR "Add validate support for list kind #14726" is merged
|
||||||
# Post-condition: mock service and mock rc are replaced
|
kubectl replace -f $replace_file --force --validate=false "${kube_flags[@]}"
|
||||||
kube::test::get_object_assert 'services mock' "{{${labels_field}.status}}" 'replaced'
|
# Post-condition: mock service and mock rc are replaced
|
||||||
kube::test::get_object_assert 'rc mock' "{{${labels_field}.status}}" 'replaced'
|
kube::test::get_object_assert 'services mock' "{{${labels_field}.status}}" 'replaced'
|
||||||
# Command
|
kube::test::get_object_assert 'rc mock' "{{${labels_field}.status}}" 'replaced'
|
||||||
kubectl label -f hack/testdata/multi-resource-list.json labeled=true "${kube_flags[@]}"
|
# Command
|
||||||
# Post-condition: mock service and mock rc are labeled
|
kubectl label -f $file labeled=true "${kube_flags[@]}"
|
||||||
kube::test::get_object_assert 'services mock' "{{${labels_field}.labeled}}" 'true'
|
# Post-condition: mock service and mock rc are labeled
|
||||||
kube::test::get_object_assert 'rc mock' "{{${labels_field}.labeled}}" 'true'
|
kube::test::get_object_assert 'services mock' "{{${labels_field}.labeled}}" 'true'
|
||||||
# Command
|
kube::test::get_object_assert 'rc mock' "{{${labels_field}.labeled}}" 'true'
|
||||||
kubectl annotate -f hack/testdata/multi-resource-list.json annotated=true "${kube_flags[@]}"
|
# Command
|
||||||
# Post-condition: mock service and mock rc are annotated
|
kubectl annotate -f $file annotated=true "${kube_flags[@]}"
|
||||||
kube::test::get_object_assert 'services mock' "{{${annotations_field}.annotated}}" 'true'
|
# Post-condition: mock service and mock rc are annotated
|
||||||
kube::test::get_object_assert 'rc mock' "{{${annotations_field}.annotated}}" 'true'
|
kube::test::get_object_assert 'services mock' "{{${annotations_field}.annotated}}" 'true'
|
||||||
# Cleanup services and rc
|
kube::test::get_object_assert 'rc mock' "{{${annotations_field}.annotated}}" 'true'
|
||||||
kubectl delete -f hack/testdata/multi-resource-list.json "${kube_flags[@]}"
|
# Cleanup services and rc
|
||||||
|
kubectl delete -f $file "${kube_flags[@]}"
|
||||||
### Create, get, describe, replace, label, annotate, and then delete service nginxsvc and replication controller my-nginx from JSON, with JSON object concatenation
|
done
|
||||||
# Pre-condition: no service (other than default kubernetes services) or replication controller is running
|
|
||||||
kube::test::get_object_assert services "{{range.items}}{{$id_field}}:{{end}}" 'kubernetes:'
|
|
||||||
kube::test::get_object_assert rc "{{range.items}}{{$id_field}}:{{end}}" ''
|
|
||||||
# Command
|
|
||||||
kubectl create -f hack/testdata/multi-resource.json "${kube_flags[@]}"
|
|
||||||
# Post-condition: mock service is running
|
|
||||||
kube::test::get_object_assert services "{{range.items}}{{$id_field}}:{{end}}" 'kubernetes:mock:'
|
|
||||||
# Post-condition: mock rc is running
|
|
||||||
kube::test::get_object_assert rc "{{range.items}}{{$id_field}}:{{end}}" 'mock:'
|
|
||||||
# Command
|
|
||||||
kubectl get -f hack/testdata/multi-resource.json "${kube_flags[@]}"
|
|
||||||
kubectl describe -f hack/testdata/multi-resource.json "${kube_flags[@]}"
|
|
||||||
# Command
|
|
||||||
kubectl replace -f hack/testdata/multi-resource-modify.json --force "${kube_flags[@]}"
|
|
||||||
# Post-condition: mock service and mock rc are replaced
|
|
||||||
kube::test::get_object_assert 'services mock' "{{${labels_field}.status}}" 'replaced'
|
|
||||||
kube::test::get_object_assert 'rc mock' "{{${labels_field}.status}}" 'replaced'
|
|
||||||
# Command
|
|
||||||
kubectl label -f hack/testdata/multi-resource.json labeled=true "${kube_flags[@]}"
|
|
||||||
# Post-condition: mock service and mock rc are labeled
|
|
||||||
kube::test::get_object_assert 'services mock' "{{${labels_field}.labeled}}" 'true'
|
|
||||||
kube::test::get_object_assert 'rc mock' "{{${labels_field}.labeled}}" 'true'
|
|
||||||
# Command
|
|
||||||
kubectl annotate -f hack/testdata/multi-resource.json annotated=true "${kube_flags[@]}"
|
|
||||||
# Post-condition: mock service and mock rc are annotated
|
|
||||||
kube::test::get_object_assert 'services mock' "{{${annotations_field}.annotated}}" 'true'
|
|
||||||
kube::test::get_object_assert 'rc mock' "{{${annotations_field}.annotated}}" 'true'
|
|
||||||
# Cleanup services and rc
|
|
||||||
kubectl delete -f hack/testdata/multi-resource.json "${kube_flags[@]}"
|
|
||||||
|
|
||||||
######################
|
######################
|
||||||
# Persistent Volumes #
|
# Persistent Volumes #
|
||||||
|
33
hack/testdata/multi-resource-yaml-modify.yaml
vendored
Normal file
33
hack/testdata/multi-resource-yaml-modify.yaml
vendored
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: mock
|
||||||
|
labels:
|
||||||
|
app: mock
|
||||||
|
status: replaced
|
||||||
|
spec:
|
||||||
|
ports:
|
||||||
|
- port: 99
|
||||||
|
protocol: TCP
|
||||||
|
targetPort: 9949
|
||||||
|
selector:
|
||||||
|
app: mock
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ReplicationController
|
||||||
|
metadata:
|
||||||
|
name: mock
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: mock
|
||||||
|
status: replaced
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: mock-container
|
||||||
|
image: kubernetes/pause
|
||||||
|
ports:
|
||||||
|
- containerPort: 9949
|
||||||
|
protocol: TCP
|
31
hack/testdata/multi-resource-yaml.yaml
vendored
Normal file
31
hack/testdata/multi-resource-yaml.yaml
vendored
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: mock
|
||||||
|
labels:
|
||||||
|
app: mock
|
||||||
|
spec:
|
||||||
|
ports:
|
||||||
|
- port: 99
|
||||||
|
protocol: TCP
|
||||||
|
targetPort: 9949
|
||||||
|
selector:
|
||||||
|
app: mock
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ReplicationController
|
||||||
|
metadata:
|
||||||
|
name: mock
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: mock
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: mock-container
|
||||||
|
image: kubernetes/pause
|
||||||
|
ports:
|
||||||
|
- containerPort: 9949
|
||||||
|
protocol: TCP
|
44
hack/testdata/nginx-app-modify.yaml
vendored
44
hack/testdata/nginx-app-modify.yaml
vendored
@ -1,44 +0,0 @@
|
|||||||
apiVersion: v1
|
|
||||||
kind: Service
|
|
||||||
metadata:
|
|
||||||
name: nginxsvc
|
|
||||||
labels:
|
|
||||||
app: nginx
|
|
||||||
status: replaced
|
|
||||||
spec:
|
|
||||||
type: NodePort
|
|
||||||
ports:
|
|
||||||
- port: 80
|
|
||||||
protocol: TCP
|
|
||||||
name: http
|
|
||||||
- port: 443
|
|
||||||
protocol: TCP
|
|
||||||
name: https
|
|
||||||
selector:
|
|
||||||
app: nginx
|
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: ReplicationController
|
|
||||||
metadata:
|
|
||||||
name: my-nginx
|
|
||||||
spec:
|
|
||||||
replicas: 1
|
|
||||||
template:
|
|
||||||
metadata:
|
|
||||||
labels:
|
|
||||||
app: nginx
|
|
||||||
status: replaced
|
|
||||||
spec:
|
|
||||||
volumes:
|
|
||||||
- name: secret-volume
|
|
||||||
secret:
|
|
||||||
secretName: nginxsecret
|
|
||||||
containers:
|
|
||||||
- name: nginxhttps
|
|
||||||
image: bprashanth/nginxhttps:1.0
|
|
||||||
ports:
|
|
||||||
- containerPort: 443
|
|
||||||
- containerPort: 80
|
|
||||||
volumeMounts:
|
|
||||||
- mountPath: /etc/nginx/ssl
|
|
||||||
name: secret-volume
|
|
Loading…
Reference in New Issue
Block a user