Skip to content

Commit

Permalink
add kubectl rollout e2e test
Browse files Browse the repository at this point in the history
  • Loading branch information
AxeZhan committed Aug 25, 2023
1 parent 10c622e commit dec1c36
Show file tree
Hide file tree
Showing 2 changed files with 166 additions and 0 deletions.
145 changes: 145 additions & 0 deletions test/e2e/kubectl/rollout.go
Original file line number Diff line number Diff line change
@@ -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)
}
})
})
})
21 changes: 21 additions & 0 deletions test/e2e/testing-manifests/kubectl/labeled-deployment.yaml.in
Original file line number Diff line number Diff line change
@@ -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

0 comments on commit dec1c36

Please sign in to comment.