add kubectl rollout e2e test

This commit is contained in:
AxeZhan 2023-08-12 20:45:48 +08:00
parent 10c622e99a
commit dec1c36125
2 changed files with 166 additions and 0 deletions

145
test/e2e/kubectl/rollout.go Normal file
View File

@ -0,0 +1,145 @@
/*
Copyright 2023 The Kubernetes Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
// OWNER = sig/cli
package kubectl
import (
"context"
"github.com/google/go-cmp/cmp"
"github.com/google/go-cmp/cmp/cmpopts"
"github.com/onsi/ginkgo/v2"
appsv1 "k8s.io/api/apps/v1"
v1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
clientset "k8s.io/client-go/kubernetes"
commonutils "k8s.io/kubernetes/test/e2e/common"
"k8s.io/kubernetes/test/e2e/framework"
e2edeployment "k8s.io/kubernetes/test/e2e/framework/deployment"
e2ekubectl "k8s.io/kubernetes/test/e2e/framework/kubectl"
admissionapi "k8s.io/pod-security-admission/api"
)
const (
labeledDeploymentFilename = "labeled-deployment.yaml.in"
)
var _ = SIGDescribe("Kubectl rollout", func() {
defer ginkgo.GinkgoRecover()
f := framework.NewDefaultFramework("kubectl-rollout")
f.NamespacePodSecurityLevel = admissionapi.LevelBaseline
var c clientset.Interface
var ns string
ginkgo.BeforeEach(func() {
c = f.ClientSet
ns = f.Namespace.Name
})
ginkgo.Describe("undo", func() {
deploymentYaml := commonutils.SubstituteImageName(string(readTestFileOrDie(labeledDeploymentFilename)))
ginkgo.AfterEach(func() {
cleanupKubectlInputs(deploymentYaml, ns, "labels_foo=labels_bar")
})
ginkgo.It("undo should rollback and update deployment env", func(ctx context.Context) {
var err error
// create deployment
e2ekubectl.RunKubectlOrDieInput(ns, deploymentYaml, "apply", "-f", "-")
replica := int32(1)
d := &appsv1.Deployment{
ObjectMeta: metav1.ObjectMeta{
Name: "pause-deployment",
Namespace: ns,
},
Spec: appsv1.DeploymentSpec{Replicas: &replica},
}
if err = e2edeployment.WaitForDeploymentComplete(c, d); err != nil {
framework.Failf("created deployment not ready")
}
if d, err = c.AppsV1().Deployments(ns).Get(ctx, "pause-deployment", metav1.GetOptions{}); err != nil {
framework.Failf("get deployment failed")
}
origEnv := d.Spec.Template.Spec.Containers[0].Env
origLabels := d.Spec.Template.Labels
origAnnotations := d.Spec.Template.Annotations
for _, env := range origEnv {
if env.Name == "foo" && env.Value == "bar" {
framework.Failf("labeled deployment should not have an env named foo and valued bar at the beginning")
}
}
// do a small update
if _, err = e2ekubectl.RunKubectl(ns, "set", "env", "deployment/pause-deployment", "foo=bar"); err != nil {
framework.Failf("kubectl failed set env for deployment")
}
// wait for env to be set
if err = e2edeployment.WaitForDeploymentComplete(c, d); err != nil {
framework.Failf("update deployment failed")
}
if d, err = c.AppsV1().Deployments(ns).Get(ctx, "pause-deployment", metav1.GetOptions{}); err != nil {
framework.Failf("get deployment failed")
}
envs := d.Spec.Template.Spec.Containers[0].Env
envUpdated := false
for _, env := range envs {
if env.Name == "foo" && env.Value == "bar" {
envUpdated = true
break
}
}
if !envUpdated {
framework.Failf("update deployment's env failed")
}
// rollback
if _, err = e2ekubectl.RunKubectl(ns, "rollout", "undo", "deployment/pause-deployment"); err != nil {
framework.Failf("kubectl failed to rollback deployment")
}
// wait for rollback finished
if err = e2edeployment.WaitForDeploymentComplete(c, d); err != nil {
framework.Failf("rollback deployment failed")
}
if d, err = c.AppsV1().Deployments(ns).Get(ctx, "pause-deployment", metav1.GetOptions{}); err != nil {
framework.Failf("get deployment failed")
}
rollbackedEnv := d.Spec.Template.Spec.Containers[0].Env
rollbackedLabels := d.Spec.Template.Labels
rollbackedAnnotations := d.Spec.Template.Annotations
if diff := cmp.Diff(origEnv, rollbackedEnv, cmpopts.SortSlices(func(a, b v1.EnvVar) bool {
return a.Name < b.Name
})); diff != "" {
framework.Failf("inconsistent env after rolled back: %s", diff)
}
if diff := cmp.Diff(origLabels, rollbackedLabels); diff != "" {
framework.Failf("inconsistent labels after rolled back: %s", diff)
}
if diff := cmp.Diff(origAnnotations, rollbackedAnnotations); diff != "" {
framework.Failf("inconsistent annotations after rolled back: %s", diff)
}
})
})
})

View File

@ -0,0 +1,21 @@
apiVersion: apps/v1
kind: Deployment
metadata:
name: pause-deployment
spec:
replicas: 1
selector:
matchLabels:
labels_foo: labels_bar
template:
metadata:
labels:
labels_foo: labels_bar
annotations:
annotations_foo: annotations_bar
spec:
containers:
- name: pause
image: {{.PauseImage}}
ports:
- containerPort: 80