mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-29 06:27:05 +00:00
fed: Add type-agnostic e2e crud test
This commit is contained in:
parent
f96b187fcb
commit
d979210e61
@ -12,6 +12,7 @@ go_library(
|
|||||||
srcs = [
|
srcs = [
|
||||||
"apiserver.go",
|
"apiserver.go",
|
||||||
"authn.go",
|
"authn.go",
|
||||||
|
"crud.go",
|
||||||
"daemonset.go",
|
"daemonset.go",
|
||||||
"deployment.go",
|
"deployment.go",
|
||||||
"event.go",
|
"event.go",
|
||||||
@ -29,6 +30,7 @@ go_library(
|
|||||||
"//federation/apis/federation/v1beta1:go_default_library",
|
"//federation/apis/federation/v1beta1:go_default_library",
|
||||||
"//federation/client/clientset_generated/federation_clientset:go_default_library",
|
"//federation/client/clientset_generated/federation_clientset:go_default_library",
|
||||||
"//federation/client/clientset_generated/federation_clientset/typed/core/v1:go_default_library",
|
"//federation/client/clientset_generated/federation_clientset/typed/core/v1:go_default_library",
|
||||||
|
"//federation/pkg/federatedtypes:go_default_library",
|
||||||
"//federation/pkg/federation-controller/replicaset:go_default_library",
|
"//federation/pkg/federation-controller/replicaset:go_default_library",
|
||||||
"//federation/pkg/federation-controller/util:go_default_library",
|
"//federation/pkg/federation-controller/util:go_default_library",
|
||||||
"//pkg/api:go_default_library",
|
"//pkg/api:go_default_library",
|
||||||
|
53
test/e2e_federation/crud.go
Normal file
53
test/e2e_federation/crud.go
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2017 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 e2e_federation
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
. "github.com/onsi/ginkgo"
|
||||||
|
|
||||||
|
"k8s.io/kubernetes/federation/pkg/federatedtypes"
|
||||||
|
kubeclientset "k8s.io/kubernetes/pkg/client/clientset_generated/clientset"
|
||||||
|
"k8s.io/kubernetes/test/e2e/framework"
|
||||||
|
fedframework "k8s.io/kubernetes/test/e2e_federation/framework"
|
||||||
|
)
|
||||||
|
|
||||||
|
var _ = framework.KubeDescribe("Federated types [Feature:Federation][Experimental] ", func() {
|
||||||
|
var clusterClients []kubeclientset.Interface
|
||||||
|
|
||||||
|
f := fedframework.NewDefaultFederatedFramework("federated-types")
|
||||||
|
|
||||||
|
for name, fedType := range federatedtypes.FederatedTypes() {
|
||||||
|
Describe(fmt.Sprintf("Federated %q resources", name), func() {
|
||||||
|
It("should be created, read, updated and deleted successfully", func() {
|
||||||
|
fedframework.SkipUnlessFederated(f.ClientSet)
|
||||||
|
|
||||||
|
// Load clients only if not skipping to avoid doing
|
||||||
|
// unnecessary work. Assume clients can be shared
|
||||||
|
// across tests.
|
||||||
|
if clusterClients == nil {
|
||||||
|
clusterClients = f.GetClusterClients()
|
||||||
|
}
|
||||||
|
adapter := fedType.AdapterFactory(f.FederationClientset)
|
||||||
|
crudTester := fedframework.NewFederatedTypeCRUDTester(adapter, clusterClients)
|
||||||
|
obj := adapter.NewTestObject(f.FederationNamespace.Name)
|
||||||
|
crudTester.CheckLifecycle(obj)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
@ -11,6 +11,7 @@ go_library(
|
|||||||
name = "go_default_library",
|
name = "go_default_library",
|
||||||
srcs = [
|
srcs = [
|
||||||
"cluster.go",
|
"cluster.go",
|
||||||
|
"crudtester.go",
|
||||||
"framework.go",
|
"framework.go",
|
||||||
"util.go",
|
"util.go",
|
||||||
],
|
],
|
||||||
@ -18,6 +19,8 @@ go_library(
|
|||||||
deps = [
|
deps = [
|
||||||
"//federation/apis/federation/v1beta1:go_default_library",
|
"//federation/apis/federation/v1beta1:go_default_library",
|
||||||
"//federation/client/clientset_generated/federation_clientset:go_default_library",
|
"//federation/client/clientset_generated/federation_clientset:go_default_library",
|
||||||
|
"//federation/pkg/federatedtypes:go_default_library",
|
||||||
|
"//federation/pkg/federatedtypes/crudtester:go_default_library",
|
||||||
"//pkg/api:go_default_library",
|
"//pkg/api:go_default_library",
|
||||||
"//pkg/api/v1:go_default_library",
|
"//pkg/api/v1:go_default_library",
|
||||||
"//pkg/api/validation:go_default_library",
|
"//pkg/api/validation:go_default_library",
|
||||||
|
44
test/e2e_federation/framework/crudtester.go
Normal file
44
test/e2e_federation/framework/crudtester.go
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2017 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 framework
|
||||||
|
|
||||||
|
import (
|
||||||
|
. "github.com/onsi/ginkgo"
|
||||||
|
"k8s.io/kubernetes/federation/pkg/federatedtypes"
|
||||||
|
"k8s.io/kubernetes/federation/pkg/federatedtypes/crudtester"
|
||||||
|
kubeclientset "k8s.io/kubernetes/pkg/client/clientset_generated/clientset"
|
||||||
|
"k8s.io/kubernetes/test/e2e/framework"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Adapt the methods to log/fail in e2e to the interface expected by CRUDHelper
|
||||||
|
type e2eTestLogger struct{}
|
||||||
|
|
||||||
|
func (e2eTestLogger) Fatal(msg string) {
|
||||||
|
Fail(msg)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e2eTestLogger) Fatalf(format string, args ...interface{}) {
|
||||||
|
framework.Failf(format, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e2eTestLogger) Logf(format string, args ...interface{}) {
|
||||||
|
framework.Logf(format, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewFederatedTypeCRUDTester(adapter federatedtypes.FederatedTypeAdapter, clusterClients []kubeclientset.Interface) *crudtester.FederatedTypeCRUDTester {
|
||||||
|
return crudtester.NewFederatedTypeCRUDTester(&e2eTestLogger{}, adapter, clusterClients, framework.Poll, FederatedDefaultTestTimeout)
|
||||||
|
}
|
@ -27,6 +27,7 @@ import (
|
|||||||
"k8s.io/apimachinery/pkg/util/wait"
|
"k8s.io/apimachinery/pkg/util/wait"
|
||||||
"k8s.io/kubernetes/federation/client/clientset_generated/federation_clientset"
|
"k8s.io/kubernetes/federation/client/clientset_generated/federation_clientset"
|
||||||
"k8s.io/kubernetes/pkg/api/v1"
|
"k8s.io/kubernetes/pkg/api/v1"
|
||||||
|
kubeclientset "k8s.io/kubernetes/pkg/client/clientset_generated/clientset"
|
||||||
"k8s.io/kubernetes/test/e2e/framework"
|
"k8s.io/kubernetes/test/e2e/framework"
|
||||||
|
|
||||||
. "github.com/onsi/ginkgo"
|
. "github.com/onsi/ginkgo"
|
||||||
@ -229,3 +230,12 @@ func (f *Framework) GetUnderlyingFederatedContexts() []E2EContext {
|
|||||||
func (f *Framework) GetRegisteredClusters() ClusterSlice {
|
func (f *Framework) GetRegisteredClusters() ClusterSlice {
|
||||||
return getRegisteredClusters(f)
|
return getRegisteredClusters(f)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (f *Framework) GetClusterClients() []kubeclientset.Interface {
|
||||||
|
clusters := getRegisteredClusters(f)
|
||||||
|
var clusterClients []kubeclientset.Interface
|
||||||
|
for _, c := range clusters {
|
||||||
|
clusterClients = append(clusterClients, c.Clientset)
|
||||||
|
}
|
||||||
|
return clusterClients
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user