mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-28 14:07:14 +00:00
Test loading Kubelet config from a file
This commit is contained in:
parent
a235ba4e49
commit
251e8f5f1f
@ -3,6 +3,7 @@ package(default_visibility = ["//visibility:public"])
|
|||||||
load(
|
load(
|
||||||
"@io_bazel_rules_go//go:def.bzl",
|
"@io_bazel_rules_go//go:def.bzl",
|
||||||
"go_library",
|
"go_library",
|
||||||
|
"go_test",
|
||||||
)
|
)
|
||||||
|
|
||||||
go_library(
|
go_library(
|
||||||
@ -29,3 +30,19 @@ filegroup(
|
|||||||
srcs = [":package-srcs"],
|
srcs = [":package-srcs"],
|
||||||
tags = ["automanaged"],
|
tags = ["automanaged"],
|
||||||
)
|
)
|
||||||
|
|
||||||
|
go_test(
|
||||||
|
name = "go_default_test",
|
||||||
|
srcs = ["configfiles_test.go"],
|
||||||
|
library = ":go_default_library",
|
||||||
|
deps = [
|
||||||
|
"//pkg/kubelet/apis/kubeletconfig:go_default_library",
|
||||||
|
"//pkg/kubelet/apis/kubeletconfig/scheme:go_default_library",
|
||||||
|
"//pkg/kubelet/apis/kubeletconfig/v1alpha1:go_default_library",
|
||||||
|
"//pkg/kubelet/kubeletconfig/util/files:go_default_library",
|
||||||
|
"//pkg/kubelet/kubeletconfig/util/filesystem:go_default_library",
|
||||||
|
"//pkg/kubelet/kubeletconfig/util/test:go_default_library",
|
||||||
|
"//vendor/github.com/davecgh/go-spew/spew:go_default_library",
|
||||||
|
"//vendor/k8s.io/apimachinery/pkg/api/equality:go_default_library",
|
||||||
|
],
|
||||||
|
)
|
||||||
|
@ -27,6 +27,8 @@ import (
|
|||||||
utilfs "k8s.io/kubernetes/pkg/kubelet/kubeletconfig/util/filesystem"
|
utilfs "k8s.io/kubernetes/pkg/kubelet/kubeletconfig/util/filesystem"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const kubeletFile = "kubelet"
|
||||||
|
|
||||||
// Loader loads configuration from a storage layer
|
// Loader loads configuration from a storage layer
|
||||||
type Loader interface {
|
type Loader interface {
|
||||||
// Load loads and returns the KubeletConfiguration from the storage layer, or an error if a configuration could not be loaded
|
// Load loads and returns the KubeletConfiguration from the storage layer, or an error if a configuration could not be loaded
|
||||||
@ -43,8 +45,8 @@ type fsLoader struct {
|
|||||||
configDir string
|
configDir string
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewFSLoader returns a Loader that loads a KubeletConfiguration from the files in `configDir`
|
// NewFsLoader returns a Loader that loads a KubeletConfiguration from the files in `configDir`
|
||||||
func NewFSLoader(fs utilfs.Filesystem, configDir string) (Loader, error) {
|
func NewFsLoader(fs utilfs.Filesystem, configDir string) (Loader, error) {
|
||||||
_, kubeletCodecs, err := kubeletscheme.NewSchemeAndCodecs()
|
_, kubeletCodecs, err := kubeletscheme.NewSchemeAndCodecs()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -58,10 +60,8 @@ func NewFSLoader(fs utilfs.Filesystem, configDir string) (Loader, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (loader *fsLoader) Load() (*kubeletconfig.KubeletConfiguration, error) {
|
func (loader *fsLoader) Load() (*kubeletconfig.KubeletConfiguration, error) {
|
||||||
errfmt := fmt.Sprintf("failed to load Kubelet config files from %q, error: ", loader.configDir) + "%v"
|
|
||||||
|
|
||||||
// require the config be in a file called "kubelet"
|
// require the config be in a file called "kubelet"
|
||||||
path := filepath.Join(loader.configDir, "kubelet")
|
path := filepath.Join(loader.configDir, kubeletFile)
|
||||||
data, err := loader.fs.ReadFile(path)
|
data, err := loader.fs.ReadFile(path)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, fmt.Errorf("failed to read init config file %q, error: %v", path, err)
|
return nil, fmt.Errorf("failed to read init config file %q, error: %v", path, err)
|
||||||
@ -69,7 +69,7 @@ func (loader *fsLoader) Load() (*kubeletconfig.KubeletConfiguration, error) {
|
|||||||
|
|
||||||
// no configuration is an error, some parameters are required
|
// no configuration is an error, some parameters are required
|
||||||
if len(data) == 0 {
|
if len(data) == 0 {
|
||||||
return nil, fmt.Errorf(errfmt, fmt.Errorf("config file was empty, but some parameters are required"))
|
return nil, fmt.Errorf("init config file %q was empty, but some parameters are required", path)
|
||||||
}
|
}
|
||||||
|
|
||||||
return utilcodec.DecodeKubeletConfiguration(loader.kubeletCodecs, data)
|
return utilcodec.DecodeKubeletConfiguration(loader.kubeletCodecs, data)
|
||||||
|
115
pkg/kubelet/kubeletconfig/configfiles/configfiles_test.go
Normal file
115
pkg/kubelet/kubeletconfig/configfiles/configfiles_test.go
Normal file
@ -0,0 +1,115 @@
|
|||||||
|
/*
|
||||||
|
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 configfiles
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"path/filepath"
|
||||||
|
"strings"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/davecgh/go-spew/spew"
|
||||||
|
|
||||||
|
apiequality "k8s.io/apimachinery/pkg/api/equality"
|
||||||
|
"k8s.io/kubernetes/pkg/kubelet/apis/kubeletconfig"
|
||||||
|
kubeletscheme "k8s.io/kubernetes/pkg/kubelet/apis/kubeletconfig/scheme"
|
||||||
|
kubeletconfigv1alpha1 "k8s.io/kubernetes/pkg/kubelet/apis/kubeletconfig/v1alpha1"
|
||||||
|
utilfiles "k8s.io/kubernetes/pkg/kubelet/kubeletconfig/util/files"
|
||||||
|
utilfs "k8s.io/kubernetes/pkg/kubelet/kubeletconfig/util/filesystem"
|
||||||
|
utiltest "k8s.io/kubernetes/pkg/kubelet/kubeletconfig/util/test"
|
||||||
|
)
|
||||||
|
|
||||||
|
func addFile(fs utilfs.Filesystem, path string, file string) error {
|
||||||
|
if err := utilfiles.EnsureDir(fs, filepath.Dir(path)); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if err := utilfiles.ReplaceFile(fs, path, []byte(file)); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestLoad(t *testing.T) {
|
||||||
|
kubeletScheme, _, err := kubeletscheme.NewSchemeAndCodecs()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("unexpected error: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// get the built-in default configuration
|
||||||
|
external := &kubeletconfigv1alpha1.KubeletConfiguration{}
|
||||||
|
kubeletScheme.Default(external)
|
||||||
|
defaultConfig := &kubeletconfig.KubeletConfiguration{}
|
||||||
|
err = kubeletScheme.Convert(external, defaultConfig, nil)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("unexpected error: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
cases := []struct {
|
||||||
|
desc string
|
||||||
|
file string
|
||||||
|
expect *kubeletconfig.KubeletConfiguration
|
||||||
|
err string
|
||||||
|
}{
|
||||||
|
{"empty data", ``, nil, "was empty"},
|
||||||
|
// invalid format
|
||||||
|
{"invalid yaml", `*`, nil, "failed to decode"},
|
||||||
|
{"invalid json", `{*`, nil, "failed to decode"},
|
||||||
|
// invalid object
|
||||||
|
{"missing kind", `{"apiVersion":"kubeletconfig/v1alpha1"}`, nil, "failed to decode"},
|
||||||
|
{"missing version", `{"kind":"KubeletConfiguration"}`, nil, "failed to decode"},
|
||||||
|
{"unregistered kind", `{"kind":"BogusKind","apiVersion":"kubeletconfig/v1alpha1"}`, nil, "failed to decode"},
|
||||||
|
{"unregistered version", `{"kind":"KubeletConfiguration","apiVersion":"bogusversion"}`, nil, "failed to decode"},
|
||||||
|
// empty object with correct kind and version should result in the defaults for that kind and version
|
||||||
|
{"default from yaml", `kind: KubeletConfiguration
|
||||||
|
apiVersion: kubeletconfig/v1alpha1`, defaultConfig, ""},
|
||||||
|
{"default from json", `{"kind":"KubeletConfiguration","apiVersion":"kubeletconfig/v1alpha1"}`, defaultConfig, ""},
|
||||||
|
}
|
||||||
|
|
||||||
|
fs := utilfs.NewFakeFs()
|
||||||
|
for i := range cases {
|
||||||
|
dir := fmt.Sprintf("/%d", i)
|
||||||
|
if err := addFile(fs, filepath.Join(dir, kubeletFile), cases[i].file); err != nil {
|
||||||
|
t.Fatalf("unexpected error: %v", err)
|
||||||
|
}
|
||||||
|
loader, err := NewFsLoader(fs, dir)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("unexpected error: %v", err)
|
||||||
|
}
|
||||||
|
kc, err := loader.Load()
|
||||||
|
if utiltest.SkipRest(t, cases[i].desc, err, cases[i].err) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
// we expect the parsed configuration to match what we described in the ConfigMap
|
||||||
|
if !apiequality.Semantic.DeepEqual(cases[i].expect, kc) {
|
||||||
|
t.Errorf("case %q, expect config %s but got %s", cases[i].desc, spew.Sdump(cases[i].expect), spew.Sdump(kc))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// finally test for a missing file
|
||||||
|
desc := "missing kubelet file"
|
||||||
|
contains := "failed to read"
|
||||||
|
loader, err := NewFsLoader(fs, "/fake")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("unexpected error: %v", err)
|
||||||
|
}
|
||||||
|
_, err = loader.Load()
|
||||||
|
if err == nil {
|
||||||
|
t.Errorf("case %q, expect error to contain %q but got nil error", desc, contains)
|
||||||
|
} else if !strings.Contains(err.Error(), contains) {
|
||||||
|
t.Errorf("case %q, expect error to contain %q but got %q", desc, contains, err.Error())
|
||||||
|
}
|
||||||
|
}
|
@ -87,7 +87,7 @@ func NewController(initConfigDir string,
|
|||||||
|
|
||||||
var initLoader configfiles.Loader
|
var initLoader configfiles.Loader
|
||||||
if len(initConfigDir) > 0 {
|
if len(initConfigDir) > 0 {
|
||||||
initLoader, err = configfiles.NewFSLoader(fs, initConfigDir)
|
initLoader, err = configfiles.NewFsLoader(fs, initConfigDir)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user