mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-23 19:56:01 +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(
|
||||
"@io_bazel_rules_go//go:def.bzl",
|
||||
"go_library",
|
||||
"go_test",
|
||||
)
|
||||
|
||||
go_library(
|
||||
@ -29,3 +30,19 @@ filegroup(
|
||||
srcs = [":package-srcs"],
|
||||
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"
|
||||
)
|
||||
|
||||
const kubeletFile = "kubelet"
|
||||
|
||||
// Loader loads configuration from a storage layer
|
||||
type Loader interface {
|
||||
// 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
|
||||
}
|
||||
|
||||
// NewFSLoader returns a Loader that loads a KubeletConfiguration from the files in `configDir`
|
||||
func NewFSLoader(fs utilfs.Filesystem, configDir string) (Loader, error) {
|
||||
// NewFsLoader returns a Loader that loads a KubeletConfiguration from the files in `configDir`
|
||||
func NewFsLoader(fs utilfs.Filesystem, configDir string) (Loader, error) {
|
||||
_, kubeletCodecs, err := kubeletscheme.NewSchemeAndCodecs()
|
||||
if err != nil {
|
||||
return nil, err
|
||||
@ -58,10 +60,8 @@ func NewFSLoader(fs utilfs.Filesystem, configDir string) (Loader, 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"
|
||||
path := filepath.Join(loader.configDir, "kubelet")
|
||||
path := filepath.Join(loader.configDir, kubeletFile)
|
||||
data, err := loader.fs.ReadFile(path)
|
||||
if err != nil {
|
||||
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
|
||||
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)
|
||||
|
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
|
||||
if len(initConfigDir) > 0 {
|
||||
initLoader, err = configfiles.NewFSLoader(fs, initConfigDir)
|
||||
initLoader, err = configfiles.NewFsLoader(fs, initConfigDir)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user