mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-22 19:31:44 +00:00
Split GetUpgradeContext to a dedicated file
This commit is contained in:
parent
23d4b3b4f0
commit
811d4aaaf6
@ -18,14 +18,9 @@ package gcp
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"path"
|
|
||||||
"strings"
|
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
utilversion "k8s.io/apimachinery/pkg/util/version"
|
|
||||||
"k8s.io/client-go/discovery"
|
|
||||||
"k8s.io/kubernetes/test/e2e/framework"
|
"k8s.io/kubernetes/test/e2e/framework"
|
||||||
e2econfig "k8s.io/kubernetes/test/e2e/framework/config"
|
|
||||||
e2eskipper "k8s.io/kubernetes/test/e2e/framework/skipper"
|
e2eskipper "k8s.io/kubernetes/test/e2e/framework/skipper"
|
||||||
"k8s.io/kubernetes/test/e2e/upgrades"
|
"k8s.io/kubernetes/test/e2e/upgrades"
|
||||||
"k8s.io/kubernetes/test/e2e/upgrades/apps"
|
"k8s.io/kubernetes/test/e2e/upgrades/apps"
|
||||||
@ -39,11 +34,6 @@ import (
|
|||||||
"github.com/onsi/ginkgo"
|
"github.com/onsi/ginkgo"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
|
||||||
upgradeTarget = e2econfig.Flags.String("upgrade-target", "ci/latest", "Version to upgrade to (e.g. 'release/stable', 'release/latest', 'ci/latest', '0.19.1', '0.19.1-669-gabac8c8') if doing an upgrade test.")
|
|
||||||
upgradeImage = e2econfig.Flags.String("upgrade-image", "", "Image to upgrade to (e.g. 'container_vm' or 'gci') if doing an upgrade test.")
|
|
||||||
)
|
|
||||||
|
|
||||||
const etcdImage = "3.4.9-1"
|
const etcdImage = "3.4.9-1"
|
||||||
|
|
||||||
var upgradeTests = []upgrades.Test{
|
var upgradeTests = []upgrades.Test{
|
||||||
@ -97,7 +87,7 @@ var _ = ginkgo.Describe("Upgrade [Feature:Upgrade]", func() {
|
|||||||
// in a "Describe".
|
// in a "Describe".
|
||||||
ginkgo.Describe("master upgrade", func() {
|
ginkgo.Describe("master upgrade", func() {
|
||||||
ginkgo.It("should maintain a functioning cluster [Feature:MasterUpgrade]", func() {
|
ginkgo.It("should maintain a functioning cluster [Feature:MasterUpgrade]", func() {
|
||||||
upgCtx, err := getUpgradeContext(f.ClientSet.Discovery(), *upgradeTarget, *upgradeImage)
|
upgCtx, err := GetUpgradeContext(f.ClientSet.Discovery())
|
||||||
framework.ExpectNoError(err)
|
framework.ExpectNoError(err)
|
||||||
|
|
||||||
testSuite := &junit.TestSuite{Name: "Master upgrade"}
|
testSuite := &junit.TestSuite{Name: "Master upgrade"}
|
||||||
@ -114,7 +104,7 @@ var _ = ginkgo.Describe("Upgrade [Feature:Upgrade]", func() {
|
|||||||
|
|
||||||
ginkgo.Describe("cluster upgrade", func() {
|
ginkgo.Describe("cluster upgrade", func() {
|
||||||
ginkgo.It("should maintain a functioning cluster [Feature:ClusterUpgrade]", func() {
|
ginkgo.It("should maintain a functioning cluster [Feature:ClusterUpgrade]", func() {
|
||||||
upgCtx, err := getUpgradeContext(f.ClientSet.Discovery(), *upgradeTarget, *upgradeImage)
|
upgCtx, err := GetUpgradeContext(f.ClientSet.Discovery())
|
||||||
framework.ExpectNoError(err)
|
framework.ExpectNoError(err)
|
||||||
|
|
||||||
testSuite := &junit.TestSuite{Name: "Cluster upgrade"}
|
testSuite := &junit.TestSuite{Name: "Cluster upgrade"}
|
||||||
@ -133,7 +123,7 @@ var _ = ginkgo.Describe("Downgrade [Feature:Downgrade]", func() {
|
|||||||
|
|
||||||
ginkgo.Describe("cluster downgrade", func() {
|
ginkgo.Describe("cluster downgrade", func() {
|
||||||
ginkgo.It("should maintain a functioning cluster [Feature:ClusterDowngrade]", func() {
|
ginkgo.It("should maintain a functioning cluster [Feature:ClusterDowngrade]", func() {
|
||||||
upgCtx, err := getUpgradeContext(f.ClientSet.Discovery(), *upgradeTarget, *upgradeImage)
|
upgCtx, err := GetUpgradeContext(f.ClientSet.Discovery())
|
||||||
framework.ExpectNoError(err)
|
framework.ExpectNoError(err)
|
||||||
|
|
||||||
testSuite := &junit.TestSuite{Name: "Cluster downgrade"}
|
testSuite := &junit.TestSuite{Name: "Cluster downgrade"}
|
||||||
@ -151,7 +141,7 @@ var _ = ginkgo.Describe("etcd Upgrade [Feature:EtcdUpgrade]", func() {
|
|||||||
|
|
||||||
ginkgo.Describe("etcd upgrade", func() {
|
ginkgo.Describe("etcd upgrade", func() {
|
||||||
ginkgo.It("should maintain a functioning cluster", func() {
|
ginkgo.It("should maintain a functioning cluster", func() {
|
||||||
upgCtx, err := getUpgradeContext(f.ClientSet.Discovery(), *upgradeTarget, *upgradeImage)
|
upgCtx, err := GetUpgradeContext(f.ClientSet.Discovery())
|
||||||
framework.ExpectNoError(err)
|
framework.ExpectNoError(err)
|
||||||
|
|
||||||
testSuite := &junit.TestSuite{Name: "Etcd upgrade"}
|
testSuite := &junit.TestSuite{Name: "Etcd upgrade"}
|
||||||
@ -174,7 +164,7 @@ var _ = ginkgo.Describe("gpu Upgrade [Feature:GPUUpgrade]", func() {
|
|||||||
|
|
||||||
ginkgo.Describe("master upgrade", func() {
|
ginkgo.Describe("master upgrade", func() {
|
||||||
ginkgo.It("should NOT disrupt gpu pod [Feature:GPUMasterUpgrade]", func() {
|
ginkgo.It("should NOT disrupt gpu pod [Feature:GPUMasterUpgrade]", func() {
|
||||||
upgCtx, err := getUpgradeContext(f.ClientSet.Discovery(), *upgradeTarget, *upgradeImage)
|
upgCtx, err := GetUpgradeContext(f.ClientSet.Discovery())
|
||||||
framework.ExpectNoError(err)
|
framework.ExpectNoError(err)
|
||||||
|
|
||||||
testSuite := &junit.TestSuite{Name: "GPU master upgrade"}
|
testSuite := &junit.TestSuite{Name: "GPU master upgrade"}
|
||||||
@ -187,7 +177,7 @@ var _ = ginkgo.Describe("gpu Upgrade [Feature:GPUUpgrade]", func() {
|
|||||||
})
|
})
|
||||||
ginkgo.Describe("cluster upgrade", func() {
|
ginkgo.Describe("cluster upgrade", func() {
|
||||||
ginkgo.It("should be able to run gpu pod after upgrade [Feature:GPUClusterUpgrade]", func() {
|
ginkgo.It("should be able to run gpu pod after upgrade [Feature:GPUClusterUpgrade]", func() {
|
||||||
upgCtx, err := getUpgradeContext(f.ClientSet.Discovery(), *upgradeTarget, *upgradeImage)
|
upgCtx, err := GetUpgradeContext(f.ClientSet.Discovery())
|
||||||
framework.ExpectNoError(err)
|
framework.ExpectNoError(err)
|
||||||
|
|
||||||
testSuite := &junit.TestSuite{Name: "GPU cluster upgrade"}
|
testSuite := &junit.TestSuite{Name: "GPU cluster upgrade"}
|
||||||
@ -200,7 +190,7 @@ var _ = ginkgo.Describe("gpu Upgrade [Feature:GPUUpgrade]", func() {
|
|||||||
})
|
})
|
||||||
ginkgo.Describe("cluster downgrade", func() {
|
ginkgo.Describe("cluster downgrade", func() {
|
||||||
ginkgo.It("should be able to run gpu pod after downgrade [Feature:GPUClusterDowngrade]", func() {
|
ginkgo.It("should be able to run gpu pod after downgrade [Feature:GPUClusterDowngrade]", func() {
|
||||||
upgCtx, err := getUpgradeContext(f.ClientSet.Discovery(), *upgradeTarget, *upgradeImage)
|
upgCtx, err := GetUpgradeContext(f.ClientSet.Discovery())
|
||||||
framework.ExpectNoError(err)
|
framework.ExpectNoError(err)
|
||||||
|
|
||||||
testSuite := &junit.TestSuite{Name: "GPU cluster downgrade"}
|
testSuite := &junit.TestSuite{Name: "GPU cluster downgrade"}
|
||||||
@ -219,7 +209,7 @@ var _ = ginkgo.Describe("[sig-apps] stateful Upgrade [Feature:StatefulUpgrade]",
|
|||||||
|
|
||||||
ginkgo.Describe("stateful upgrade", func() {
|
ginkgo.Describe("stateful upgrade", func() {
|
||||||
ginkgo.It("should maintain a functioning cluster", func() {
|
ginkgo.It("should maintain a functioning cluster", func() {
|
||||||
upgCtx, err := getUpgradeContext(f.ClientSet.Discovery(), *upgradeTarget, *upgradeImage)
|
upgCtx, err := GetUpgradeContext(f.ClientSet.Discovery())
|
||||||
framework.ExpectNoError(err)
|
framework.ExpectNoError(err)
|
||||||
|
|
||||||
testSuite := &junit.TestSuite{Name: "Stateful upgrade"}
|
testSuite := &junit.TestSuite{Name: "Stateful upgrade"}
|
||||||
@ -242,7 +232,7 @@ var _ = ginkgo.Describe("kube-proxy migration [Feature:KubeProxyDaemonSetMigrati
|
|||||||
|
|
||||||
ginkgo.Describe("Upgrade kube-proxy from static pods to a DaemonSet", func() {
|
ginkgo.Describe("Upgrade kube-proxy from static pods to a DaemonSet", func() {
|
||||||
ginkgo.It("should maintain a functioning cluster [Feature:KubeProxyDaemonSetUpgrade]", func() {
|
ginkgo.It("should maintain a functioning cluster [Feature:KubeProxyDaemonSetUpgrade]", func() {
|
||||||
upgCtx, err := getUpgradeContext(f.ClientSet.Discovery(), *upgradeTarget, *upgradeImage)
|
upgCtx, err := GetUpgradeContext(f.ClientSet.Discovery())
|
||||||
framework.ExpectNoError(err)
|
framework.ExpectNoError(err)
|
||||||
|
|
||||||
testSuite := &junit.TestSuite{Name: "kube-proxy upgrade"}
|
testSuite := &junit.TestSuite{Name: "kube-proxy upgrade"}
|
||||||
@ -260,7 +250,7 @@ var _ = ginkgo.Describe("kube-proxy migration [Feature:KubeProxyDaemonSetMigrati
|
|||||||
|
|
||||||
ginkgo.Describe("Downgrade kube-proxy from a DaemonSet to static pods", func() {
|
ginkgo.Describe("Downgrade kube-proxy from a DaemonSet to static pods", func() {
|
||||||
ginkgo.It("should maintain a functioning cluster [Feature:KubeProxyDaemonSetDowngrade]", func() {
|
ginkgo.It("should maintain a functioning cluster [Feature:KubeProxyDaemonSetDowngrade]", func() {
|
||||||
upgCtx, err := getUpgradeContext(f.ClientSet.Discovery(), *upgradeTarget, *upgradeImage)
|
upgCtx, err := GetUpgradeContext(f.ClientSet.Discovery())
|
||||||
framework.ExpectNoError(err)
|
framework.ExpectNoError(err)
|
||||||
|
|
||||||
testSuite := &junit.TestSuite{Name: "kube-proxy downgrade"}
|
testSuite := &junit.TestSuite{Name: "kube-proxy downgrade"}
|
||||||
@ -283,7 +273,7 @@ var _ = ginkgo.Describe("[sig-auth] ServiceAccount admission controller migratio
|
|||||||
|
|
||||||
ginkgo.Describe("master upgrade", func() {
|
ginkgo.Describe("master upgrade", func() {
|
||||||
ginkgo.It("should maintain a functioning cluster", func() {
|
ginkgo.It("should maintain a functioning cluster", func() {
|
||||||
upgCtx, err := getUpgradeContext(f.ClientSet.Discovery(), *upgradeTarget, *upgradeImage)
|
upgCtx, err := GetUpgradeContext(f.ClientSet.Discovery())
|
||||||
framework.ExpectNoError(err)
|
framework.ExpectNoError(err)
|
||||||
|
|
||||||
testSuite := &junit.TestSuite{Name: "ServiceAccount admission controller migration"}
|
testSuite := &junit.TestSuite{Name: "ServiceAccount admission controller migration"}
|
||||||
@ -299,57 +289,3 @@ var _ = ginkgo.Describe("[sig-auth] ServiceAccount admission controller migratio
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
func getUpgradeContext(c discovery.DiscoveryInterface, upgradeTarget, upgradeImage string) (*upgrades.UpgradeContext, error) {
|
|
||||||
current, err := c.ServerVersion()
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
curVer, err := utilversion.ParseSemantic(current.String())
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
upgCtx := &upgrades.UpgradeContext{
|
|
||||||
Versions: []upgrades.VersionContext{
|
|
||||||
{
|
|
||||||
Version: *curVer,
|
|
||||||
NodeImage: framework.TestContext.NodeOSDistro,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(upgradeTarget) == 0 {
|
|
||||||
return upgCtx, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
next, err := realVersion(upgradeTarget)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
nextVer, err := utilversion.ParseSemantic(next)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
upgCtx.Versions = append(upgCtx.Versions, upgrades.VersionContext{
|
|
||||||
Version: *nextVer,
|
|
||||||
NodeImage: upgradeImage,
|
|
||||||
})
|
|
||||||
|
|
||||||
return upgCtx, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// realVersion turns a version constants into a version string deployable on
|
|
||||||
// GKE. See hack/get-build.sh for more information.
|
|
||||||
func realVersion(s string) (string, error) {
|
|
||||||
framework.Logf("Getting real version for %q", s)
|
|
||||||
v, _, err := framework.RunCmd(path.Join(framework.TestContext.RepoRoot, "hack/get-build.sh"), "-v", s)
|
|
||||||
if err != nil {
|
|
||||||
return v, fmt.Errorf("error getting real version for %q: %v", s, err)
|
|
||||||
}
|
|
||||||
framework.Logf("Version for %q is %q", s, v)
|
|
||||||
return strings.TrimPrefix(strings.TrimSpace(v), "v"), nil
|
|
||||||
}
|
|
||||||
|
89
test/e2e/cloud/gcp/upgrade_context.go
Normal file
89
test/e2e/cloud/gcp/upgrade_context.go
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2016 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package gcp
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"path"
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
utilversion "k8s.io/apimachinery/pkg/util/version"
|
||||||
|
"k8s.io/client-go/discovery"
|
||||||
|
"k8s.io/kubernetes/test/e2e/framework"
|
||||||
|
e2econfig "k8s.io/kubernetes/test/e2e/framework/config"
|
||||||
|
"k8s.io/kubernetes/test/e2e/upgrades"
|
||||||
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
upgradeTarget = e2econfig.Flags.String("upgrade-target", "ci/latest", "Version to upgrade to (e.g. 'release/stable', 'release/latest', 'ci/latest', '0.19.1', '0.19.1-669-gabac8c8') if doing an upgrade test.")
|
||||||
|
upgradeImage = e2econfig.Flags.String("upgrade-image", "", "Image to upgrade to (e.g. 'container_vm' or 'gci') if doing an upgrade test.")
|
||||||
|
)
|
||||||
|
|
||||||
|
// GetUpgradeContext return UpgradeContext for GCP provider.
|
||||||
|
func GetUpgradeContext(c discovery.DiscoveryInterface) (*upgrades.UpgradeContext, error) {
|
||||||
|
current, err := c.ServerVersion()
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
curVer, err := utilversion.ParseSemantic(current.String())
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
upgCtx := &upgrades.UpgradeContext{
|
||||||
|
Versions: []upgrades.VersionContext{
|
||||||
|
{
|
||||||
|
Version: *curVer,
|
||||||
|
NodeImage: framework.TestContext.NodeOSDistro,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(*upgradeTarget) == 0 {
|
||||||
|
return upgCtx, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
next, err := realVersion(*upgradeTarget)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
nextVer, err := utilversion.ParseSemantic(next)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
upgCtx.Versions = append(upgCtx.Versions, upgrades.VersionContext{
|
||||||
|
Version: *nextVer,
|
||||||
|
NodeImage: *upgradeImage,
|
||||||
|
})
|
||||||
|
|
||||||
|
return upgCtx, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// realVersion turns a version constants into a version string deployable on
|
||||||
|
// GKE. See hack/get-build.sh for more information.
|
||||||
|
func realVersion(s string) (string, error) {
|
||||||
|
framework.Logf("Getting real version for %q", s)
|
||||||
|
v, _, err := framework.RunCmd(path.Join(framework.TestContext.RepoRoot, "hack/get-build.sh"), "-v", s)
|
||||||
|
if err != nil {
|
||||||
|
return v, fmt.Errorf("error getting real version for %q: %v", s, err)
|
||||||
|
}
|
||||||
|
framework.Logf("Version for %q is %q", s, v)
|
||||||
|
return strings.TrimPrefix(strings.TrimSpace(v), "v"), nil
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user