talos/internal/integration/base/discovery_k8s.go
Andrey Smirnov a059454045
chore: build using Go 1.17
`initramfs` size for amd64 shrinks by 1.3 MiB.

Signed-off-by: Andrey Smirnov <andrey.smirnov@talos-systems.com>
2021-09-13 22:33:47 +03:00

84 lines
1.9 KiB
Go

// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
//go:build integration_k8s
// +build integration_k8s
package base
import (
"context"
"time"
v1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/client-go/kubernetes"
"k8s.io/client-go/tools/clientcmd"
clientcmdapi "k8s.io/client-go/tools/clientcmd/api"
"github.com/talos-systems/talos/pkg/cluster"
"github.com/talos-systems/talos/pkg/machinery/client"
"github.com/talos-systems/talos/pkg/machinery/constants"
)
//nolint:gocyclo
func discoverNodesK8s(client *client.Client, suite *TalosSuite) (cluster.Info, error) {
ctx, ctxCancel := context.WithTimeout(context.Background(), time.Minute)
defer ctxCancel()
kubeconfig, err := client.Kubeconfig(ctx)
if err != nil {
return nil, err
}
config, err := clientcmd.BuildConfigFromKubeconfigGetter("", func() (*clientcmdapi.Config, error) {
return clientcmd.Load(kubeconfig)
})
if err != nil {
return nil, err
}
// patch timeout
config.Timeout = time.Minute
if suite.K8sEndpoint != "" {
config.Host = suite.K8sEndpoint
}
clientset, err := kubernetes.NewForConfig(config)
if err != nil {
return nil, err
}
nodes, err := clientset.CoreV1().Nodes().List(ctx, metav1.ListOptions{})
if err != nil {
return nil, err
}
result := &infoWrapper{}
for _, node := range nodes.Items {
var address string
for _, nodeAddress := range node.Status.Addresses {
if nodeAddress.Type == v1.NodeInternalIP {
address = nodeAddress.Address
break
}
}
if address == "" {
continue
}
if _, ok := node.Labels[constants.LabelNodeRoleMaster]; ok {
result.masterNodes = append(result.masterNodes, address)
} else {
result.workerNodes = append(result.workerNodes, address)
}
}
return result, nil
}