mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-30 15:05:27 +00:00
kubeadm: Improve kubeadm init cmd tests
kubeadm init cmd tests are improved in the following ways: - Fix a few cases that were always successful (despite completely wrong). - Add more test cases (for different configs in particular) - Use dry run, to avoid modifying the system and using kubeadm reset Signed-off-by: Rostislav M. Georgiev <rostislavg@vmware.com>
This commit is contained in:
parent
8b4cdd0f85
commit
961d776fac
@ -30,7 +30,10 @@ go_test(
|
||||
"integration",
|
||||
"skip",
|
||||
],
|
||||
deps = ["//vendor/github.com/ghodss/yaml:go_default_library"],
|
||||
deps = [
|
||||
"//vendor/github.com/ghodss/yaml:go_default_library",
|
||||
"//vendor/github.com/renstrom/dedent:go_default_library",
|
||||
],
|
||||
)
|
||||
|
||||
filegroup(
|
||||
|
@ -16,12 +16,16 @@ limitations under the License.
|
||||
|
||||
package kubeadm
|
||||
|
||||
import "testing"
|
||||
import (
|
||||
"testing"
|
||||
|
||||
// kubeadmReset executes "kubeadm reset" and restarts kubelet.
|
||||
func kubeadmReset() error {
|
||||
_, _, err := RunCmd(*kubeadmPath, "reset")
|
||||
return err
|
||||
"github.com/renstrom/dedent"
|
||||
)
|
||||
|
||||
func runKubeadmInit(args ...string) (string, string, error) {
|
||||
kubeadmArgs := []string{"init", "--dry-run", "--ignore-preflight-errors=all"}
|
||||
kubeadmArgs = append(kubeadmArgs, args...)
|
||||
return RunCmd(*kubeadmPath, kubeadmArgs...)
|
||||
}
|
||||
|
||||
func TestCmdInitToken(t *testing.T) {
|
||||
@ -30,26 +34,46 @@ func TestCmdInitToken(t *testing.T) {
|
||||
t.Skip()
|
||||
}
|
||||
|
||||
var initTest = []struct {
|
||||
initTest := []struct {
|
||||
name string
|
||||
args string
|
||||
expected bool
|
||||
}{
|
||||
{"--discovery=token://abcd:1234567890abcd", false}, // invalid token size
|
||||
{"--discovery=token://Abcdef:1234567890abcdef", false}, // invalid token non-lowercase
|
||||
{
|
||||
name: "invalid token size",
|
||||
args: "--token=abcd:1234567890abcd",
|
||||
expected: false,
|
||||
},
|
||||
{
|
||||
name: "invalid token non-lowercase",
|
||||
args: "--token=Abcdef:1234567890abcdef",
|
||||
expected: false,
|
||||
},
|
||||
{
|
||||
name: "valid token is accepted",
|
||||
args: "--token=abcdef.0123456789abcdef",
|
||||
expected: true,
|
||||
},
|
||||
}
|
||||
|
||||
for _, rt := range initTest {
|
||||
_, _, actual := RunCmd(*kubeadmPath, "init", rt.args, "--skip-preflight-checks")
|
||||
if (actual == nil) != rt.expected {
|
||||
t.Errorf(
|
||||
"failed CmdInitToken running 'kubeadm init %s' with an error: %v\n\texpected: %t\n\t actual: %t",
|
||||
rt.args,
|
||||
actual,
|
||||
rt.expected,
|
||||
(actual == nil),
|
||||
)
|
||||
}
|
||||
kubeadmReset()
|
||||
t.Run(rt.name, func(t *testing.T) {
|
||||
_, _, err := runKubeadmInit(rt.args)
|
||||
if (err == nil) != rt.expected {
|
||||
t.Fatalf(dedent.Dedent(`
|
||||
CmdInitToken test case %q failed with an error: %v
|
||||
command 'kubeadm init %s'
|
||||
expected: %t
|
||||
err: %t
|
||||
`),
|
||||
rt.name,
|
||||
err,
|
||||
rt.args,
|
||||
rt.expected,
|
||||
(err == nil),
|
||||
)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
@ -59,25 +83,41 @@ func TestCmdInitKubernetesVersion(t *testing.T) {
|
||||
t.Skip()
|
||||
}
|
||||
|
||||
var initTest = []struct {
|
||||
initTest := []struct {
|
||||
name string
|
||||
args string
|
||||
expected bool
|
||||
}{
|
||||
{"--kubernetes-version=foobar", false},
|
||||
{
|
||||
name: "invalid version string is detected",
|
||||
args: "--kubernetes-version=foobar",
|
||||
expected: false,
|
||||
},
|
||||
{
|
||||
name: "valid version is accepted",
|
||||
args: "--kubernetes-version=1.11.0",
|
||||
expected: true,
|
||||
},
|
||||
}
|
||||
|
||||
for _, rt := range initTest {
|
||||
_, _, actual := RunCmd(*kubeadmPath, "init", rt.args, "--skip-preflight-checks")
|
||||
if (actual == nil) != rt.expected {
|
||||
t.Errorf(
|
||||
"failed CmdInitKubernetesVersion running 'kubeadm init %s' with an error: %v\n\texpected: %t\n\t actual: %t",
|
||||
rt.args,
|
||||
actual,
|
||||
rt.expected,
|
||||
(actual == nil),
|
||||
)
|
||||
}
|
||||
kubeadmReset()
|
||||
t.Run(rt.name, func(t *testing.T) {
|
||||
_, _, err := runKubeadmInit(rt.args)
|
||||
if (err == nil) != rt.expected {
|
||||
t.Fatalf(dedent.Dedent(`
|
||||
CmdInitKubernetesVersion test case %q failed with an error: %v
|
||||
command 'kubeadm init %s'
|
||||
expected: %t
|
||||
err: %t
|
||||
`),
|
||||
rt.name,
|
||||
err,
|
||||
rt.args,
|
||||
rt.expected,
|
||||
(err == nil),
|
||||
)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
@ -87,26 +127,56 @@ func TestCmdInitConfig(t *testing.T) {
|
||||
t.Skip()
|
||||
}
|
||||
|
||||
var initTest = []struct {
|
||||
initTest := []struct {
|
||||
name string
|
||||
args string
|
||||
expected bool
|
||||
}{
|
||||
{"--config=foobar", false},
|
||||
{"--config=/does/not/exist/foo/bar", false},
|
||||
{
|
||||
name: "fail on non existing path",
|
||||
args: "--config=/does/not/exist/foo/bar",
|
||||
expected: false,
|
||||
},
|
||||
{
|
||||
name: "can't load v1alpha1 config",
|
||||
args: "--config=testdata/init/v1alpha1.yaml",
|
||||
expected: false,
|
||||
},
|
||||
{
|
||||
name: "can load v1alpha2 config",
|
||||
args: "--config=testdata/init/v1alpha2.yaml",
|
||||
expected: true,
|
||||
},
|
||||
{
|
||||
name: "can load v1alpha3 config",
|
||||
args: "--config=testdata/init/v1alpha3.yaml",
|
||||
expected: true,
|
||||
},
|
||||
{
|
||||
name: "don't allow mixed arguments",
|
||||
args: "--kubernetes-version=1.11.0 --config=testdata/init/v1alpha3.yaml",
|
||||
expected: false,
|
||||
},
|
||||
}
|
||||
|
||||
for _, rt := range initTest {
|
||||
_, _, actual := RunCmd(*kubeadmPath, "init", rt.args, "--skip-preflight-checks")
|
||||
if (actual == nil) != rt.expected {
|
||||
t.Errorf(
|
||||
"failed CmdInitConfig running 'kubeadm init %s' with an error: %v\n\texpected: %t\n\t actual: %t",
|
||||
rt.args,
|
||||
actual,
|
||||
rt.expected,
|
||||
(actual == nil),
|
||||
)
|
||||
}
|
||||
kubeadmReset()
|
||||
t.Run(rt.name, func(t *testing.T) {
|
||||
_, _, err := runKubeadmInit(rt.args)
|
||||
if (err == nil) != rt.expected {
|
||||
t.Fatalf(dedent.Dedent(`
|
||||
CmdInitConfig test case %q failed with an error: %v
|
||||
command 'kubeadm init %s'
|
||||
expected: %t
|
||||
err: %t
|
||||
`),
|
||||
rt.name,
|
||||
err,
|
||||
rt.args,
|
||||
rt.expected,
|
||||
(err == nil),
|
||||
)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
@ -116,52 +186,50 @@ func TestCmdInitAPIPort(t *testing.T) {
|
||||
t.Skip()
|
||||
}
|
||||
|
||||
var initTest = []struct {
|
||||
initTest := []struct {
|
||||
name string
|
||||
args string
|
||||
expected bool
|
||||
}{
|
||||
{"--api-port=foobar", false},
|
||||
{
|
||||
name: "fail on non-string port",
|
||||
args: "--apiserver-bind-port=foobar",
|
||||
expected: false,
|
||||
},
|
||||
{
|
||||
name: "fail on too large port number",
|
||||
args: "--apiserver-bind-port=100000",
|
||||
expected: false,
|
||||
},
|
||||
{
|
||||
name: "fail on negative port number",
|
||||
args: "--apiserver-bind-port=-6000",
|
||||
expected: false,
|
||||
},
|
||||
{
|
||||
name: "accept a valid port number",
|
||||
args: "--apiserver-bind-port=6000",
|
||||
expected: true,
|
||||
},
|
||||
}
|
||||
|
||||
for _, rt := range initTest {
|
||||
_, _, actual := RunCmd(*kubeadmPath, "init", rt.args, "--skip-preflight-checks")
|
||||
if (actual == nil) != rt.expected {
|
||||
t.Errorf(
|
||||
"failed CmdInitAPIPort running 'kubeadm init %s' with an error: %v\n\texpected: %t\n\t actual: %t",
|
||||
rt.args,
|
||||
actual,
|
||||
rt.expected,
|
||||
(actual == nil),
|
||||
)
|
||||
}
|
||||
kubeadmReset()
|
||||
}
|
||||
}
|
||||
|
||||
func TestCmdInitArgsMixed(t *testing.T) {
|
||||
if *kubeadmCmdSkip {
|
||||
t.Log("kubeadm cmd tests being skipped")
|
||||
t.Skip()
|
||||
}
|
||||
|
||||
var initTest = []struct {
|
||||
args string
|
||||
expected bool
|
||||
}{
|
||||
{"--api-port=1000 --config=/etc/kubernets/kubeadm.config", false},
|
||||
}
|
||||
|
||||
for _, rt := range initTest {
|
||||
_, _, actual := RunCmd(*kubeadmPath, "init", rt.args, "--skip-preflight-checks")
|
||||
if (actual == nil) != rt.expected {
|
||||
t.Errorf(
|
||||
"failed CmdInitArgsMixed running 'kubeadm init %s' with an error: %v\n\texpected: %t\n\t actual: %t",
|
||||
rt.args,
|
||||
actual,
|
||||
rt.expected,
|
||||
(actual == nil),
|
||||
)
|
||||
}
|
||||
kubeadmReset()
|
||||
t.Run(rt.name, func(t *testing.T) {
|
||||
_, _, err := runKubeadmInit(rt.args)
|
||||
if (err == nil) != rt.expected {
|
||||
t.Fatalf(dedent.Dedent(`
|
||||
CmdInitAPIPort test case %q failed with an error: %v
|
||||
command 'kubeadm init %s'
|
||||
expected: %t
|
||||
err: %t
|
||||
`),
|
||||
rt.name,
|
||||
err,
|
||||
rt.args,
|
||||
rt.expected,
|
||||
(err == nil),
|
||||
)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
@ -18,6 +18,12 @@ package kubeadm
|
||||
|
||||
import "testing"
|
||||
|
||||
// kubeadmReset executes "kubeadm reset" and restarts kubelet.
|
||||
func kubeadmReset() error {
|
||||
_, _, err := RunCmd(*kubeadmPath, "reset")
|
||||
return err
|
||||
}
|
||||
|
||||
func TestCmdJoinConfig(t *testing.T) {
|
||||
if *kubeadmCmdSkip {
|
||||
t.Log("kubeadm cmd tests being skipped")
|
||||
|
2
cmd/kubeadm/test/cmd/testdata/init/v1alpha1.yaml
vendored
Normal file
2
cmd/kubeadm/test/cmd/testdata/init/v1alpha1.yaml
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
apiVersion: kubeadm.k8s.io/v1alpha1
|
||||
kind: MasterConfiguration
|
2
cmd/kubeadm/test/cmd/testdata/init/v1alpha2.yaml
vendored
Normal file
2
cmd/kubeadm/test/cmd/testdata/init/v1alpha2.yaml
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
apiVersion: kubeadm.k8s.io/v1alpha2
|
||||
kind: MasterConfiguration
|
2
cmd/kubeadm/test/cmd/testdata/init/v1alpha3.yaml
vendored
Normal file
2
cmd/kubeadm/test/cmd/testdata/init/v1alpha3.yaml
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
apiVersion: kubeadm.k8s.io/v1alpha3
|
||||
kind: InitConfiguration
|
Loading…
Reference in New Issue
Block a user