Skip to content
This repository has been archived by the owner on Jan 6, 2023. It is now read-only.

Commit

Permalink
Support take over label selector
Browse files Browse the repository at this point in the history
  • Loading branch information
wzshiming committed May 11, 2022
1 parent 250b4d0 commit 1d1c092
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 1 deletion.
3 changes: 3 additions & 0 deletions cmd/fake-kubelet/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ var (
nodeIP = net.ParseIP(getEnv("NODE_IP", "196.168.0.1"))
nodeName = getEnv("NODE_NAME", "fake")
takeOverAll = getEnvBool("TAKE_OVER_ALL", false)
takeOverLabelSelector = getEnv("TAKE_OVER_LABEL_SELECTOR", "type=fake-kubelet")
generateNodeName = getEnv("GENERATE_NODE_NAME", "")
generateReplicas = getEnv("GENERATE_REPLICAS", "0")
kubeconfig = getEnv("KUBECONFIG", "")
Expand All @@ -45,6 +46,7 @@ func init() {
pflag.IPVar(&nodeIP, "node_ip", nodeIP, "node ip")
pflag.StringVarP(&nodeName, "node_name", "n", nodeName, "node name")
pflag.BoolVar(&takeOverAll, "take_over_all", takeOverAll, "take over all node")
pflag.StringVar(&takeOverLabelSelector, "take_over_label_selector", takeOverLabelSelector, "take over label selector")
pflag.StringVar(&kubeconfig, "kubeconfig", kubeconfig, "kubeconfig")
pflag.StringVar(&master, "master", master, "master")
pflag.StringVar(&serverAddress, "server_address", serverAddress, "server address")
Expand Down Expand Up @@ -92,6 +94,7 @@ func main() {
ClientSet: clientset,
Nodes: nodes,
TakeOverAll: takeOverAll,
TakeOverLabelSelector: takeOverLabelSelector,
CIDR: cidr,
NodeIP: nodeIP.String(),
Logger: logger,
Expand Down
11 changes: 10 additions & 1 deletion controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import (
"time"

corev1 "k8s.io/api/core/v1"
"k8s.io/apimachinery/pkg/labels"
"k8s.io/client-go/kubernetes"
"sigs.k8s.io/yaml"
)
Expand Down Expand Up @@ -49,6 +50,7 @@ type Config struct {
ClientSet kubernetes.Interface
Nodes []string
TakeOverAll bool
TakeOverLabelSelector string
CIDR string
NodeIP string
Logger Logger
Expand All @@ -64,12 +66,19 @@ type Logger interface {

// NewController creates a new fake kubelet controller
func NewController(conf Config) (*Controller, error) {

var nodeSelectorFunc func(node *corev1.Node) bool
if conf.TakeOverAll {
nodeSelectorFunc = func(node *corev1.Node) bool {
return true
}
} else if conf.TakeOverLabelSelector != "" {
selector, err := labels.Parse(conf.TakeOverLabelSelector)
if err != nil {
return nil, err
}
nodeSelectorFunc = func(node *corev1.Node) bool {
return selector.Matches(labels.Set(node.Labels))
}
}

var lockPodsOnNodeFunc func(ctx context.Context, nodeName string) error
Expand Down
4 changes: 4 additions & 0 deletions deploy.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -254,6 +254,10 @@ spec:
value: fake-
- name: GENERATE_REPLICAS
value: "5"
- name: TAKE_OVER_LABEL_SELECTOR
value: type=fake-kubelet
- name: TAKE_OVER_ALL
value: "false"
- name: CIDR
value: 10.0.0.1/24
- name: HEALTH_ADDRESS
Expand Down

0 comments on commit 1d1c092

Please sign in to comment.