mirror of
https://github.com/kubernetes/client-go.git
synced 2025-06-23 21:57:30 +00:00
Merge pull request #119410 from Jefftree/kubectl-cleanup
Cleanup kubectl legacy server fallback Kubernetes-commit: ea3353dd6b8c3ba52516230a5e70b1af0ff9192b
This commit is contained in:
commit
4783d28359
@ -648,16 +648,7 @@ func (d *DiscoveryClient) ServerVersion() (*version.Info, error) {
|
|||||||
func (d *DiscoveryClient) OpenAPISchema() (*openapi_v2.Document, error) {
|
func (d *DiscoveryClient) OpenAPISchema() (*openapi_v2.Document, error) {
|
||||||
data, err := d.restClient.Get().AbsPath("/openapi/v2").SetHeader("Accept", openAPIV2mimePb).Do(context.TODO()).Raw()
|
data, err := d.restClient.Get().AbsPath("/openapi/v2").SetHeader("Accept", openAPIV2mimePb).Do(context.TODO()).Raw()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if errors.IsForbidden(err) || errors.IsNotFound(err) || errors.IsNotAcceptable(err) {
|
return nil, err
|
||||||
// single endpoint not found/registered in old server, try to fetch old endpoint
|
|
||||||
// TODO: remove this when kubectl/client-go don't work with 1.9 server
|
|
||||||
data, err = d.restClient.Get().AbsPath("/swagger-2.0.0.pb-v1").Do(context.TODO()).Raw()
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
document := &openapi_v2.Document{}
|
document := &openapi_v2.Document{}
|
||||||
err = proto.Unmarshal(data, document)
|
err = proto.Unmarshal(data, document)
|
||||||
|
@ -492,43 +492,6 @@ func returnedOpenAPI() *openapi_v2.Document {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func openapiSchemaDeprecatedFakeServer(status int, t *testing.T) (*httptest.Server, error) {
|
|
||||||
server := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, req *http.Request) {
|
|
||||||
if req.URL.Path == "/openapi/v2" {
|
|
||||||
// write the error status for the new endpoint request
|
|
||||||
w.WriteHeader(status)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if req.URL.Path != "/swagger-2.0.0.pb-v1" {
|
|
||||||
errMsg := fmt.Sprintf("Unexpected url %v", req.URL)
|
|
||||||
w.WriteHeader(http.StatusNotFound)
|
|
||||||
w.Write([]byte(errMsg))
|
|
||||||
t.Errorf("testing should fail as %s", errMsg)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if req.Method != "GET" {
|
|
||||||
errMsg := fmt.Sprintf("Unexpected method %v", req.Method)
|
|
||||||
w.WriteHeader(http.StatusMethodNotAllowed)
|
|
||||||
w.Write([]byte(errMsg))
|
|
||||||
t.Errorf("testing should fail as %s", errMsg)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
output, err := proto.Marshal(returnedOpenAPI())
|
|
||||||
if err != nil {
|
|
||||||
errMsg := fmt.Sprintf("Unexpected marshal error: %v", err)
|
|
||||||
w.WriteHeader(http.StatusInternalServerError)
|
|
||||||
w.Write([]byte(errMsg))
|
|
||||||
t.Errorf("testing should fail as %s", errMsg)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
w.WriteHeader(http.StatusOK)
|
|
||||||
w.Write(output)
|
|
||||||
}))
|
|
||||||
|
|
||||||
return server, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func openapiSchemaFakeServer(t *testing.T) (*httptest.Server, error) {
|
func openapiSchemaFakeServer(t *testing.T) (*httptest.Server, error) {
|
||||||
server := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, req *http.Request) {
|
server := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, req *http.Request) {
|
||||||
if req.URL.Path != "/openapi/v2" {
|
if req.URL.Path != "/openapi/v2" {
|
||||||
@ -673,57 +636,6 @@ func TestGetOpenAPISchemaV3(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestGetOpenAPISchemaForbiddenFallback(t *testing.T) {
|
|
||||||
server, err := openapiSchemaDeprecatedFakeServer(http.StatusForbidden, t)
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("unexpected error starting fake server: %v", err)
|
|
||||||
}
|
|
||||||
defer server.Close()
|
|
||||||
|
|
||||||
client := NewDiscoveryClientForConfigOrDie(&restclient.Config{Host: server.URL})
|
|
||||||
got, err := client.OpenAPISchema()
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("unexpected error getting openapi: %v", err)
|
|
||||||
}
|
|
||||||
if e, a := returnedOpenAPI(), got; !golangproto.Equal(e, a) {
|
|
||||||
t.Errorf("expected %v, got %v", e, a)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestGetOpenAPISchemaNotFoundFallback(t *testing.T) {
|
|
||||||
server, err := openapiSchemaDeprecatedFakeServer(http.StatusNotFound, t)
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("unexpected error starting fake server: %v", err)
|
|
||||||
}
|
|
||||||
defer server.Close()
|
|
||||||
|
|
||||||
client := NewDiscoveryClientForConfigOrDie(&restclient.Config{Host: server.URL})
|
|
||||||
got, err := client.OpenAPISchema()
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("unexpected error getting openapi: %v", err)
|
|
||||||
}
|
|
||||||
if e, a := returnedOpenAPI(), got; !golangproto.Equal(e, a) {
|
|
||||||
t.Errorf("expected %v, got %v", e, a)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestGetOpenAPISchemaNotAcceptableFallback(t *testing.T) {
|
|
||||||
server, err := openapiSchemaDeprecatedFakeServer(http.StatusNotAcceptable, t)
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("unexpected error starting fake server: %v", err)
|
|
||||||
}
|
|
||||||
defer server.Close()
|
|
||||||
|
|
||||||
client := NewDiscoveryClientForConfigOrDie(&restclient.Config{Host: server.URL})
|
|
||||||
got, err := client.OpenAPISchema()
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("unexpected error getting openapi: %v", err)
|
|
||||||
}
|
|
||||||
if e, a := returnedOpenAPI(), got; !golangproto.Equal(e, a) {
|
|
||||||
t.Errorf("expected %v, got %v", e, a)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestServerPreferredResources(t *testing.T) {
|
func TestServerPreferredResources(t *testing.T) {
|
||||||
stable := metav1.APIResourceList{
|
stable := metav1.APIResourceList{
|
||||||
GroupVersion: "v1",
|
GroupVersion: "v1",
|
||||||
|
Loading…
Reference in New Issue
Block a user