Skip to content

Commit

Permalink
Handle provider id changing in cluster state
Browse files Browse the repository at this point in the history
  • Loading branch information
jonathan-innis committed Jan 18, 2023
1 parent 12c3355 commit d8e85ae
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 3 deletions.
16 changes: 13 additions & 3 deletions pkg/controllers/state/cluster.go
Original file line number Diff line number Diff line change
Expand Up @@ -165,13 +165,17 @@ func (c *Cluster) UpdateNode(ctx context.Context, node *v1.Node) error {
return nil
}

func (c *Cluster) DeleteNode(nodeName string) {
func (c *Cluster) DeleteNode(name string) {
c.mu.Lock()
defer c.mu.Unlock()

if id := c.nameToProviderID[nodeName]; id != "" {
c.cleanupNode(name)
}

func (c *Cluster) cleanupNode(name string) {
if id := c.nameToProviderID[name]; id != "" {
delete(c.nodes, id)
delete(c.nameToProviderID, nodeName)
delete(c.nameToProviderID, name)
c.RecordConsolidationChange()
}
}
Expand Down Expand Up @@ -250,6 +254,12 @@ func (c *Cluster) newStateFromNode(ctx context.Context, node *v1.Node, oldNode *
); err != nil {
return nil, err
}
// Cleanup the old node with its old providerID if its providerID changes
// This can happen since nodes don't get created with providerIDs. Rather, CCM picks up the
// created node and injects the providerID into the spec.providerID
if id, ok := c.nameToProviderID[node.Name]; ok && id != node.Spec.ProviderID {
c.cleanupNode(node.Name)
}
c.triggerConsolidationOnChange(oldNode, n)
return n, nil
}
Expand Down
26 changes: 26 additions & 0 deletions pkg/controllers/state/suite_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -612,6 +612,22 @@ var _ = Describe("Node Resource Level", func() {
time.Sleep(time.Second * 6) // past 10s, node should no longer be nominated
Expect(ExpectStateNodeExists(node).Nominated()).To(BeFalse())
})
It("should handle a node changing from no providerID to registering a providerID", func() {
node := test.Node()
ExpectApplied(ctx, env.Client, node)
ExpectReconcileSucceeded(ctx, nodeController, client.ObjectKeyFromObject(node))

ExpectStateNodeCount("==", 1)
ExpectStateNodeExists(node)

// Change the providerID; this mocks CCM adding the providerID onto the node after registration
node.Spec.ProviderID = fmt.Sprintf("fake://%s", node.Name)
ExpectApplied(ctx, env.Client, node)
ExpectReconcileSucceeded(ctx, nodeController, client.ObjectKeyFromObject(node))

ExpectStateNodeCount("==", 1)
ExpectStateNodeExists(node)
})
})

var _ = Describe("Pod Anti-Affinity", func() {
Expand Down Expand Up @@ -802,6 +818,16 @@ var _ = Describe("Provisioner Spec Updates", func() {
})
})

func ExpectStateNodeCount(comparator string, count int) int {
c := 0
cluster.ForEachNode(func(n *state.Node) bool {
c++
return true
})
ExpectWithOffset(1, count).To(BeNumerically(comparator, count))
return c
}

func ExpectStateNodeExistsWithOffset(offset int, node *v1.Node) *state.Node {
var ret *state.Node
cluster.ForEachNode(func(n *state.Node) bool {
Expand Down

0 comments on commit d8e85ae

Please sign in to comment.