Skip to content

Commit

Permalink
MESH-5373: Node locality is missing occasionally.
Browse files Browse the repository at this point in the history
- Add support for update event on NodeController

Signed-off-by: Adil Fulara <[email protected]>
  • Loading branch information
Adil Fulara committed Aug 14, 2024
1 parent 033be91 commit e18ee67
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 22 deletions.
22 changes: 16 additions & 6 deletions admiral/pkg/controller/admiral/node.go
Original file line number Diff line number Diff line change
Expand Up @@ -57,19 +57,29 @@ func NewNodeController(stopCh <-chan struct{}, handler NodeHandler, config *rest
return &nodeController, nil
}

func (p *NodeController) Added(ctx context.Context, obj interface{}) error {
func process(ctx context.Context, obj interface{}) (string, error) {
node, ok := obj.(*k8sV1.Node)
if !ok {
return fmt.Errorf("type assertion failed, %v is not of type *v1.Node", obj)
return "", fmt.Errorf("type assertion failed, %v is not of type *v1.Node", obj)
}
if p.Locality == nil {
p.Locality = &Locality{Region: common.GetNodeLocality(node)}
return common.GetNodeLocality(node), nil
}

func (d *NodeController) Added(ctx context.Context, obj interface{}) error {
region, err := process(ctx, obj)
if err != nil {
return err
}
d.Locality = &Locality{Region: region}
return nil
}

func (p *NodeController) Updated(ctx context.Context, obj interface{}, oldObj interface{}) error {
//ignore
func (d *NodeController) Updated(ctx context.Context, obj interface{}, oldObj interface{}) error {
region, err := process(ctx, obj)
if err != nil {
return err
}
d.Locality = &Locality{Region: region}
return nil
}

Expand Down
24 changes: 8 additions & 16 deletions admiral/pkg/controller/admiral/node_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -102,31 +102,23 @@ func TestNodeAddUpdateDelete(t *testing.T) {

if nodeController == nil {
t.Errorf("Node controller should never be nil without an error thrown")
return
}
region := "us-west-2"
nodeObj := &k8sV1.Node{Spec: k8sV1.NodeSpec{}, ObjectMeta: v1.ObjectMeta{Labels: map[string]string{common.NodeRegionLabel: region}}}

ctx := context.Background()

nodeController.Added(ctx, nodeObj)
_ = nodeController.Added(ctx, nodeObj)
assert.Equal(t, "us-west-2", nodeController.Locality.Region, "region expected %v, got: %v", region, nodeController.Locality.Region)

locality := nodeController.Locality
nodeObj.Labels[common.NodeRegionLabel] = "us-east-2"
_ = nodeController.Updated(ctx, nodeObj, nodeObj)
assert.Equal(t, "us-east-2", nodeController.Locality.Region, "region expected %v, got: %v", region, nodeController.Locality.Region)

if locality.Region != region {
t.Errorf("region expected %v, got: %v", region, locality.Region)
}

nodeController.Updated(ctx, nodeObj, nodeObj)
//update should make no difference
if locality.Region != region {
t.Errorf("region expected %v, got: %v", region, locality.Region)
}

nodeController.Deleted(ctx, nodeObj)
_ = nodeController.Deleted(ctx, nodeObj)
//delete should make no difference
if locality.Region != region {
t.Errorf("region expected %v, got: %v", region, locality.Region)
}
assert.Equal(t, "us-east-2", nodeController.Locality.Region, "region expected %v, got: %v", region, nodeController.Locality.Region)
}

// TODO: This is just a placeholder for when we add diff check for other types
Expand Down

0 comments on commit e18ee67

Please sign in to comment.