mirror of
				https://github.com/optim-enterprises-bv/kubernetes.git
				synced 2025-10-31 18:28:13 +00:00 
			
		
		
		
	 f4e2c738f6
			
		
	
	f4e2c738f6
	
	
	
		
			
			pkg/service: There were a couple of references here just as a reminder to change the behavior of findPort. As of v1beta3, TargetPort was always defaulted, so we could remove findDefaultPort and related tests. pkg/apiserver: The tests were using versioned API codecs for some of their encoding tests. Necessary API types had to be written and registered with the fake versioned codecs. pkg/kubectl: Some tests were converted to current versions where it made sense.
		
			
				
	
	
		
			192 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			192 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| /*
 | |
| Copyright 2014 The Kubernetes Authors All rights reserved.
 | |
| 
 | |
| 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 cmd
 | |
| 
 | |
| import (
 | |
| 	"bytes"
 | |
| 	"fmt"
 | |
| 	"io"
 | |
| 	"net/http"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/spf13/cobra"
 | |
| 
 | |
| 	"github.com/GoogleCloudPlatform/kubernetes/pkg/api"
 | |
| 	"github.com/GoogleCloudPlatform/kubernetes/pkg/client"
 | |
| )
 | |
| 
 | |
| type fakeRemoteExecutor struct {
 | |
| 	req     *client.Request
 | |
| 	execErr error
 | |
| }
 | |
| 
 | |
| func (f *fakeRemoteExecutor) Execute(req *client.Request, config *client.Config, command []string, stdin io.Reader, stdout, stderr io.Writer, tty bool) error {
 | |
| 	f.req = req
 | |
| 	return f.execErr
 | |
| }
 | |
| 
 | |
| func TestPodAndContainer(t *testing.T) {
 | |
| 	tests := []struct {
 | |
| 		args              []string
 | |
| 		p                 *execParams
 | |
| 		expectError       bool
 | |
| 		expectedPod       string
 | |
| 		expectedContainer string
 | |
| 	}{
 | |
| 		{
 | |
| 			p:           &execParams{},
 | |
| 			expectError: true,
 | |
| 		},
 | |
| 		{
 | |
| 			p:           &execParams{podName: "foo"},
 | |
| 			expectError: true,
 | |
| 		},
 | |
| 		{
 | |
| 			p:           &execParams{podName: "foo", containerName: "bar"},
 | |
| 			expectError: true,
 | |
| 		},
 | |
| 		{
 | |
| 			p:           &execParams{podName: "foo"},
 | |
| 			args:        []string{"cmd"},
 | |
| 			expectedPod: "foo",
 | |
| 		},
 | |
| 		{
 | |
| 			p:           &execParams{},
 | |
| 			args:        []string{"foo"},
 | |
| 			expectError: true,
 | |
| 		},
 | |
| 		{
 | |
| 			p:           &execParams{},
 | |
| 			args:        []string{"foo", "cmd"},
 | |
| 			expectedPod: "foo",
 | |
| 		},
 | |
| 		{
 | |
| 			p:                 &execParams{containerName: "bar"},
 | |
| 			args:              []string{"foo", "cmd"},
 | |
| 			expectedPod:       "foo",
 | |
| 			expectedContainer: "bar",
 | |
| 		},
 | |
| 	}
 | |
| 	for _, test := range tests {
 | |
| 		cmd := &cobra.Command{}
 | |
| 		podName, containerName, err := extractPodAndContainer(cmd, test.args, test.p)
 | |
| 		if podName != test.expectedPod {
 | |
| 			t.Errorf("expected: %s, got: %s", test.expectedPod, podName)
 | |
| 		}
 | |
| 		if containerName != test.expectedContainer {
 | |
| 			t.Errorf("expected: %s, got: %s", test.expectedContainer, containerName)
 | |
| 		}
 | |
| 		if test.expectError && err == nil {
 | |
| 			t.Error("unexpected non-error")
 | |
| 		}
 | |
| 		if !test.expectError && err != nil {
 | |
| 			t.Errorf("unexpected error: %v", err)
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestExec(t *testing.T) {
 | |
| 	tests := []struct {
 | |
| 		name, version, podPath, execPath, container string
 | |
| 		nsInQuery                                   bool
 | |
| 		pod                                         *api.Pod
 | |
| 		execErr                                     bool
 | |
| 	}{
 | |
| 		{
 | |
| 			name:      "v1beta3 - pod exec",
 | |
| 			version:   "v1beta3",
 | |
| 			podPath:   "/api/v1beta3/namespaces/test/pods/foo",
 | |
| 			execPath:  "/api/v1beta3/namespaces/test/pods/foo/exec",
 | |
| 			nsInQuery: false,
 | |
| 			pod:       execPod(),
 | |
| 		},
 | |
| 		{
 | |
| 			name:      "v1beta3 - pod exec error",
 | |
| 			version:   "v1beta3",
 | |
| 			podPath:   "/api/v1beta3/namespaces/test/pods/foo",
 | |
| 			execPath:  "/api/v1beta3/namespaces/test/pods/foo/exec",
 | |
| 			nsInQuery: false,
 | |
| 			pod:       execPod(),
 | |
| 			execErr:   true,
 | |
| 		},
 | |
| 	}
 | |
| 	for _, test := range tests {
 | |
| 		f, tf, codec := NewAPIFactory()
 | |
| 		tf.Client = &client.FakeRESTClient{
 | |
| 			Codec: codec,
 | |
| 			Client: client.HTTPClientFunc(func(req *http.Request) (*http.Response, error) {
 | |
| 				switch p, m := req.URL.Path, req.Method; {
 | |
| 				case p == test.podPath && m == "GET":
 | |
| 					if test.nsInQuery {
 | |
| 						if ns := req.URL.Query().Get("namespace"); ns != "test" {
 | |
| 							t.Errorf("%s: did not get expected namespace: %s\n", test.name, ns)
 | |
| 						}
 | |
| 					}
 | |
| 					body := objBody(codec, test.pod)
 | |
| 					return &http.Response{StatusCode: 200, Body: body}, nil
 | |
| 				default:
 | |
| 					// Ensures no GET is performed when deleting by name
 | |
| 					t.Errorf("%s: unexpected request: %#v\n%#v", test.name, req.URL, req)
 | |
| 					return nil, nil
 | |
| 				}
 | |
| 			}),
 | |
| 		}
 | |
| 		tf.Namespace = "test"
 | |
| 		tf.ClientConfig = &client.Config{Version: test.version}
 | |
| 		bufOut := bytes.NewBuffer([]byte{})
 | |
| 		bufErr := bytes.NewBuffer([]byte{})
 | |
| 		bufIn := bytes.NewBuffer([]byte{})
 | |
| 		ex := &fakeRemoteExecutor{}
 | |
| 		if test.execErr {
 | |
| 			ex.execErr = fmt.Errorf("exec error")
 | |
| 		}
 | |
| 		params := &execParams{
 | |
| 			podName:       "foo",
 | |
| 			containerName: "bar",
 | |
| 		}
 | |
| 		cmd := &cobra.Command{}
 | |
| 		err := RunExec(f, cmd, bufIn, bufOut, bufErr, params, []string{"test", "command"}, ex)
 | |
| 		if test.execErr && err != ex.execErr {
 | |
| 			t.Errorf("%s: Unexpected exec error: %v", test.name, err)
 | |
| 		}
 | |
| 		if !test.execErr && ex.req.URL().Path != test.execPath {
 | |
| 			t.Errorf("%s: Did not get expected path for exec request", test.name)
 | |
| 		}
 | |
| 		if !test.execErr && err != nil {
 | |
| 			t.Errorf("%s: Unexpected error: %v", test.name, err)
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func execPod() *api.Pod {
 | |
| 	return &api.Pod{
 | |
| 		ObjectMeta: api.ObjectMeta{Name: "foo", Namespace: "test", ResourceVersion: "10"},
 | |
| 		Spec: api.PodSpec{
 | |
| 			RestartPolicy: api.RestartPolicyAlways,
 | |
| 			DNSPolicy:     api.DNSClusterFirst,
 | |
| 			Containers: []api.Container{
 | |
| 				{
 | |
| 					Name: "bar",
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		Status: api.PodStatus{
 | |
| 			Phase: api.PodRunning,
 | |
| 		},
 | |
| 	}
 | |
| }
 |