123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217 |
- /*
- Copyright 2015 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 v1_test
- import (
- "net/url"
- "reflect"
- "testing"
- "time"
- "k8s.io/kubernetes/pkg/api"
- "k8s.io/kubernetes/pkg/api/resource"
- "k8s.io/kubernetes/pkg/api/unversioned"
- versioned "k8s.io/kubernetes/pkg/api/v1"
- "k8s.io/kubernetes/pkg/runtime"
- "k8s.io/kubernetes/pkg/util/diff"
- )
- func TestPodLogOptions(t *testing.T) {
- sinceSeconds := int64(1)
- sinceTime := unversioned.NewTime(time.Date(2000, 1, 1, 12, 34, 56, 0, time.UTC).Local())
- tailLines := int64(2)
- limitBytes := int64(3)
- versionedLogOptions := &versioned.PodLogOptions{
- Container: "mycontainer",
- Follow: true,
- Previous: true,
- SinceSeconds: &sinceSeconds,
- SinceTime: &sinceTime,
- Timestamps: true,
- TailLines: &tailLines,
- LimitBytes: &limitBytes,
- }
- unversionedLogOptions := &api.PodLogOptions{
- Container: "mycontainer",
- Follow: true,
- Previous: true,
- SinceSeconds: &sinceSeconds,
- SinceTime: &sinceTime,
- Timestamps: true,
- TailLines: &tailLines,
- LimitBytes: &limitBytes,
- }
- expectedParameters := url.Values{
- "container": {"mycontainer"},
- "follow": {"true"},
- "previous": {"true"},
- "sinceSeconds": {"1"},
- "sinceTime": {"2000-01-01T12:34:56Z"},
- "timestamps": {"true"},
- "tailLines": {"2"},
- "limitBytes": {"3"},
- }
- codec := runtime.NewParameterCodec(api.Scheme)
- // unversioned -> query params
- {
- actualParameters, err := codec.EncodeParameters(unversionedLogOptions, versioned.SchemeGroupVersion)
- if err != nil {
- t.Fatal(err)
- }
- if !reflect.DeepEqual(actualParameters, expectedParameters) {
- t.Fatalf("Expected\n%#v\ngot\n%#v", expectedParameters, actualParameters)
- }
- }
- // versioned -> query params
- {
- actualParameters, err := codec.EncodeParameters(versionedLogOptions, versioned.SchemeGroupVersion)
- if err != nil {
- t.Fatal(err)
- }
- if !reflect.DeepEqual(actualParameters, expectedParameters) {
- t.Fatalf("Expected\n%#v\ngot\n%#v", expectedParameters, actualParameters)
- }
- }
- // query params -> versioned
- {
- convertedLogOptions := &versioned.PodLogOptions{}
- err := codec.DecodeParameters(expectedParameters, versioned.SchemeGroupVersion, convertedLogOptions)
- if err != nil {
- t.Fatal(err)
- }
- if !reflect.DeepEqual(convertedLogOptions, versionedLogOptions) {
- t.Fatalf("Unexpected deserialization:\n%s", diff.ObjectGoPrintSideBySide(versionedLogOptions, convertedLogOptions))
- }
- }
- // query params -> unversioned
- {
- convertedLogOptions := &api.PodLogOptions{}
- err := codec.DecodeParameters(expectedParameters, versioned.SchemeGroupVersion, convertedLogOptions)
- if err != nil {
- t.Fatal(err)
- }
- if !reflect.DeepEqual(convertedLogOptions, unversionedLogOptions) {
- t.Fatalf("Unexpected deserialization:\n%s", diff.ObjectGoPrintSideBySide(unversionedLogOptions, convertedLogOptions))
- }
- }
- }
- // TestPodSpecConversion tests that ServiceAccount is an alias for
- // ServiceAccountName.
- func TestPodSpecConversion(t *testing.T) {
- name, other := "foo", "bar"
- // Test internal -> v1. Should have both alias (DeprecatedServiceAccount)
- // and new field (ServiceAccountName).
- i := &api.PodSpec{
- ServiceAccountName: name,
- }
- v := versioned.PodSpec{}
- if err := api.Scheme.Convert(i, &v, nil); err != nil {
- t.Fatalf("unexpected error: %v", err)
- }
- if v.ServiceAccountName != name {
- t.Fatalf("want v1.ServiceAccountName %q, got %q", name, v.ServiceAccountName)
- }
- if v.DeprecatedServiceAccount != name {
- t.Fatalf("want v1.DeprecatedServiceAccount %q, got %q", name, v.DeprecatedServiceAccount)
- }
- // Test v1 -> internal. Either DeprecatedServiceAccount, ServiceAccountName,
- // or both should translate to ServiceAccountName. ServiceAccountName wins
- // if both are set.
- testCases := []*versioned.PodSpec{
- // New
- {ServiceAccountName: name},
- // Alias
- {DeprecatedServiceAccount: name},
- // Both: same
- {ServiceAccountName: name, DeprecatedServiceAccount: name},
- // Both: different
- {ServiceAccountName: name, DeprecatedServiceAccount: other},
- }
- for k, v := range testCases {
- got := api.PodSpec{}
- err := api.Scheme.Convert(v, &got, nil)
- if err != nil {
- t.Fatalf("unexpected error for case %d: %v", k, err)
- }
- if got.ServiceAccountName != name {
- t.Fatalf("want api.ServiceAccountName %q, got %q", name, got.ServiceAccountName)
- }
- }
- }
- func TestResourceListConversion(t *testing.T) {
- bigMilliQuantity := resource.NewQuantity(resource.MaxMilliValue, resource.DecimalSI)
- bigMilliQuantity.Add(resource.MustParse("12345m"))
- tests := []struct {
- input versioned.ResourceList
- expected api.ResourceList
- }{
- { // No changes necessary.
- input: versioned.ResourceList{
- versioned.ResourceMemory: resource.MustParse("30M"),
- versioned.ResourceCPU: resource.MustParse("100m"),
- versioned.ResourceStorage: resource.MustParse("1G"),
- },
- expected: api.ResourceList{
- api.ResourceMemory: resource.MustParse("30M"),
- api.ResourceCPU: resource.MustParse("100m"),
- api.ResourceStorage: resource.MustParse("1G"),
- },
- },
- { // Nano-scale values should be rounded up to milli-scale.
- input: versioned.ResourceList{
- versioned.ResourceCPU: resource.MustParse("3.000023m"),
- versioned.ResourceMemory: resource.MustParse("500.000050m"),
- },
- expected: api.ResourceList{
- api.ResourceCPU: resource.MustParse("4m"),
- api.ResourceMemory: resource.MustParse("501m"),
- },
- },
- { // Large values should still be accurate.
- input: versioned.ResourceList{
- versioned.ResourceCPU: *bigMilliQuantity.Copy(),
- versioned.ResourceStorage: *bigMilliQuantity.Copy(),
- },
- expected: api.ResourceList{
- api.ResourceCPU: *bigMilliQuantity.Copy(),
- api.ResourceStorage: *bigMilliQuantity.Copy(),
- },
- },
- }
- for i, test := range tests {
- output := api.ResourceList{}
- err := api.Scheme.Convert(&test.input, &output, nil)
- if err != nil {
- t.Fatalf("unexpected error for case %d: %v", i, err)
- }
- if !api.Semantic.DeepEqual(test.expected, output) {
- t.Errorf("unexpected conversion for case %d: Expected %+v; Got %+v", i, test.expected, output)
- }
- }
- }
|