mirror of
https://github.com/fluxcd/flux2.git
synced 2026-02-24 00:21:46 +00:00
Add check command
- verify minimum supported version of kubectl, kustomize and Kubernetes API
This commit is contained in:
parent
94e0b3c9c3
commit
403a0f2882
3 changed files with 96 additions and 6 deletions
|
|
@ -5,6 +5,7 @@ import (
|
||||||
"os"
|
"os"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
|
|
||||||
|
"github.com/blang/semver"
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
@ -30,19 +31,24 @@ func init() {
|
||||||
}
|
}
|
||||||
|
|
||||||
func runCheckCmd(cmd *cobra.Command, args []string) error {
|
func runCheckCmd(cmd *cobra.Command, args []string) error {
|
||||||
if !checkLocal() {
|
if !kubectlCheck(">=1.14.0") {
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if !kustomizeCheck(">=3.5.0") {
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
|
|
||||||
if checkPre {
|
if checkPre {
|
||||||
fmt.Println(`✔`, "all prerequisites checks passed")
|
fmt.Println(`✔`, "all prerequisites checks passed")
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
if !checkRemote() {
|
if !kubernetesCheck(">=1.14.0") {
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
} else {
|
|
||||||
fmt.Println(`✔`, "all checks passed")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fmt.Println(`✔`, "all checks passed")
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -57,10 +63,69 @@ func checkLocal() bool {
|
||||||
fmt.Println(`✔`, cmd, "found")
|
fmt.Println(`✔`, cmd, "found")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return ok
|
return ok
|
||||||
}
|
}
|
||||||
|
|
||||||
func checkRemote() bool {
|
func kubectlCheck(version string) bool {
|
||||||
|
_, err := exec.LookPath("kubectl")
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println(`✗`, "kubectl not found")
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
output, err := execCommand("kubectl version --client --short | awk '{ print $3 }'")
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println(`✗`, "kubectl version can't be determined")
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
v, err := semver.ParseTolerant(output)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println(`✗`, "kubectl version can't be determined")
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
rng, _ := semver.ParseRange(version)
|
||||||
|
if !rng(v) {
|
||||||
|
fmt.Println(`✗`, "kubectl version must be", version)
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
fmt.Println(`✔`, "kubectl", v.String())
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
|
func kustomizeCheck(version string) bool {
|
||||||
|
_, err := exec.LookPath("kustomize")
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println(`✗`, "kustomize not found")
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
output, err := execCommand("kustomize version --short | awk '{ print $1 }' | cut -c2-")
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println(`✗`, "kustomize version can't be determined")
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
v, err := semver.ParseTolerant(output)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println(`✗`, "kustomize version can't be determined")
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
rng, _ := semver.ParseRange(version)
|
||||||
|
if !rng(v) {
|
||||||
|
fmt.Println(`✗`, "kustomize version must be", version)
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
fmt.Println(`✔`, "kustomize", v.String())
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
|
func kubernetesCheck(version string) bool {
|
||||||
client, err := NewKubernetesClient()
|
client, err := NewKubernetesClient()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println(`✗`, "kubernetes client initialization failed", err.Error())
|
fmt.Println(`✗`, "kubernetes client initialization failed", err.Error())
|
||||||
|
|
@ -73,6 +138,27 @@ func checkRemote() bool {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
fmt.Println(`✔`, "kubernetes version", ver.String())
|
v, err := semver.ParseTolerant(ver.String())
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println(`✗`, "kubernetes version can't be determined")
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
rng, _ := semver.ParseRange(version)
|
||||||
|
if !rng(v) {
|
||||||
|
fmt.Println(`✗`, "kubernetes version must be", version)
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
fmt.Println(`✔`, "kubernetes", v.String())
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func execCommand(command string) (string, error) {
|
||||||
|
c := exec.Command("/bin/sh", "-c", command)
|
||||||
|
output, err := c.CombinedOutput()
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
return string(output), nil
|
||||||
|
}
|
||||||
|
|
|
||||||
1
go.mod
1
go.mod
|
|
@ -3,6 +3,7 @@ module github.com/fluxcd/toolkit
|
||||||
go 1.14
|
go 1.14
|
||||||
|
|
||||||
require (
|
require (
|
||||||
|
github.com/blang/semver v3.5.1+incompatible
|
||||||
github.com/spf13/cobra v0.0.6
|
github.com/spf13/cobra v0.0.6
|
||||||
k8s.io/client-go v0.18.0
|
k8s.io/client-go v0.18.0
|
||||||
)
|
)
|
||||||
|
|
|
||||||
3
go.sum
3
go.sum
|
|
@ -26,6 +26,9 @@ github.com/alecthomas/units v0.0.0-20151022065526-2efee857e7cf/go.mod h1:ybxpYRF
|
||||||
github.com/armon/consul-api v0.0.0-20180202201655-eb2c6b5be1b6/go.mod h1:grANhF5doyWs3UAsr3K4I6qtAmlQcZDesFNEHPZAzj8=
|
github.com/armon/consul-api v0.0.0-20180202201655-eb2c6b5be1b6/go.mod h1:grANhF5doyWs3UAsr3K4I6qtAmlQcZDesFNEHPZAzj8=
|
||||||
github.com/beorn7/perks v0.0.0-20180321164747-3a771d992973/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q=
|
github.com/beorn7/perks v0.0.0-20180321164747-3a771d992973/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q=
|
||||||
github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8=
|
github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8=
|
||||||
|
github.com/blang/semver v1.1.0 h1:ol1rO7QQB5uy7umSNV7VAmLugfLRD+17sYJujRNYPhg=
|
||||||
|
github.com/blang/semver v3.5.1+incompatible h1:cQNTCjp13qL8KC3Nbxr/y2Bqb63oX6wdnnjpJbkM4JQ=
|
||||||
|
github.com/blang/semver v3.5.1+incompatible/go.mod h1:kRBLl5iJ+tD4TcOOxsy/0fnwebNt5EWlYSAyrTnjyyk=
|
||||||
github.com/cespare/xxhash v1.1.0/go.mod h1:XrSqR1VqqWfGrhpAt58auRo0WTKS1nRRg3ghfAqPWnc=
|
github.com/cespare/xxhash v1.1.0/go.mod h1:XrSqR1VqqWfGrhpAt58auRo0WTKS1nRRg3ghfAqPWnc=
|
||||||
github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDkc90ppPyw=
|
github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDkc90ppPyw=
|
||||||
github.com/coreos/bbolt v1.3.2/go.mod h1:iRUV2dpdMOn7Bo10OQBFzIJO9kkE559Wcmn+qkEiiKk=
|
github.com/coreos/bbolt v1.3.2/go.mod h1:iRUV2dpdMOn7Bo10OQBFzIJO9kkE559Wcmn+qkEiiKk=
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue