From 6868e947dfd22be8939d85207ea885cdb26df836 Mon Sep 17 00:00:00 2001 From: Markus Lehtonen Date: Wed, 14 Dec 2022 20:50:49 +0200 Subject: [PATCH] nfd-master: update node if NodeFeature objects are removed Correctly handle the case where no NodeFeature objects exist for certain node. In this case all the labels should be removed. --- pkg/nfd-master/nfd-master.go | 37 ++++++++++++++++++------------------ 1 file changed, 19 insertions(+), 18 deletions(-) diff --git a/pkg/nfd-master/nfd-master.go b/pkg/nfd-master/nfd-master.go index 5589701fa6..e0e42b34b4 100644 --- a/pkg/nfd-master/nfd-master.go +++ b/pkg/nfd-master/nfd-master.go @@ -502,10 +502,7 @@ func (m *nfdMaster) nfdAPIUpdateAllNodes() error { func (m *nfdMaster) nfdAPIUpdateOneNode(nodeName string) error { sel := labels.SelectorFromSet(labels.Set{nfdv1alpha1.NodeFeatureObjNodeNameLabel: nodeName}) objs, err := m.nfdController.featureLister.List(sel) - if len(objs) == 0 { - klog.Infof("no NodeFeature object exists for node %q, skipping...", nodeName) - return nil - } else if err != nil { + if err != nil { return fmt.Errorf("failed to get NodeFeature resources for node %q: %w", nodeName, err) } @@ -532,22 +529,26 @@ func (m *nfdMaster) nfdAPIUpdateOneNode(nodeName string) error { klog.V(1).Infof("processing node %q, initiated by NodeFeature API", nodeName) - // Merge in features - // - // NOTE: changing the rule api to support handle multiple objects instead - // of merging would probably perform better with lot less data to copy. - features := objs[0].Spec.DeepCopy() - for _, o := range objs[1:] { - o.Spec.MergeInto(features) - } + features := nfdv1alpha1.NodeFeatureSpec{} + annotations := Annotations{} - utils.KlogDump(4, "Composite NodeFeatureSpec after merge:", " ", features) + if len(objs) > 0 { + // Merge in features + // + // NOTE: changing the rule api to support handle multiple objects instead + // of merging would probably perform better with lot less data to copy. + features = objs[0].Spec.DeepCopy() + for _, o := range objs[1:] { + o.Spec.MergeInto(features) + } - annotations := Annotations{} - if objs[0].Namespace == m.namespace && objs[0].Name == nodeName { - // This is the one created by nfd-worker - if v := objs[0].Annotations[nfdv1alpha1.WorkerVersionAnnotation]; v != "" { - annotations[nfdv1alpha1.WorkerVersionAnnotation] = v + utils.KlogDump(4, "Composite NodeFeatureSpec after merge:", " ", features) + + if objs[0].Namespace == m.namespace && objs[0].Name == nodeName { + // This is the one created by nfd-worker + if v := objs[0].Annotations[nfdv1alpha1.WorkerVersionAnnotation]; v != "" { + annotations[nfdv1alpha1.WorkerVersionAnnotation] = v + } } }