mirror of
https://github.com/kubernetes-sigs/node-feature-discovery.git
synced 2025-03-31 04:04:51 +00:00
Fix image compatibility processing panic in case of a nil pointer
Signed-off-by: Marcin Franczyk <marcin0franczyk@gmail.com>
This commit is contained in:
parent
f64fdd6c08
commit
25d751d781
1 changed files with 9 additions and 2 deletions
|
@ -97,6 +97,7 @@ func (nv *nodeValidator) Execute(ctx context.Context) ([]*CompatibilityStatus, e
|
|||
}
|
||||
|
||||
func evaluateRuleStatus(rule *nfdv1alpha1.Rule, matchStatus *nodefeaturerule.MatchStatus) ProcessedRuleStatus {
|
||||
var matchedFeatureTerms nfdv1alpha1.FeatureMatcher
|
||||
out := ProcessedRuleStatus{Name: rule.Name, IsMatch: matchStatus.IsMatch}
|
||||
|
||||
evaluateFeatureMatcher := func(featureMatcher, matchedFeatureTerms nfdv1alpha1.FeatureMatcher) []MatchedExpression {
|
||||
|
@ -163,11 +164,17 @@ func evaluateRuleStatus(rule *nfdv1alpha1.Rule, matchStatus *nodefeaturerule.Mat
|
|||
}
|
||||
|
||||
if matchFeatures := rule.MatchFeatures; matchFeatures != nil {
|
||||
out.MatchedExpressions = evaluateFeatureMatcher(matchFeatures, matchStatus.MatchedFeaturesTerms)
|
||||
if matchStatus.MatchFeatureStatus != nil {
|
||||
matchedFeatureTerms = matchStatus.MatchFeatureStatus.MatchedFeaturesTerms
|
||||
}
|
||||
out.MatchedExpressions = evaluateFeatureMatcher(matchFeatures, matchedFeatureTerms)
|
||||
}
|
||||
|
||||
for i, matchAnyElem := range rule.MatchAny {
|
||||
matchedExpressions := evaluateFeatureMatcher(matchAnyElem.MatchFeatures, matchStatus.MatchAny[i].MatchedFeaturesTerms)
|
||||
if matchStatus.MatchAny[i].MatchedFeaturesTerms != nil {
|
||||
matchedFeatureTerms = matchStatus.MatchAny[i].MatchedFeaturesTerms
|
||||
}
|
||||
matchedExpressions := evaluateFeatureMatcher(matchAnyElem.MatchFeatures, matchedFeatureTerms)
|
||||
out.MatchedAny = append(out.MatchedAny, MatchAnyElem{MatchedExpressions: matchedExpressions})
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue