From 5d482ab72c35c679abf56fe4587076c0f408a4be Mon Sep 17 00:00:00 2001 From: haser Date: Wed, 6 Dec 2023 21:45:42 +0800 Subject: [PATCH 1/2] [YUNIKORN-2205] remove the warning of processing nonexistent "namespace.guaranteed" --- pkg/common/utils/utils.go | 3 +++ 1 file changed, 3 insertions(+) diff --git a/pkg/common/utils/utils.go b/pkg/common/utils/utils.go index 837cd1d1b..c54d6f682 100644 --- a/pkg/common/utils/utils.go +++ b/pkg/common/utils/utils.go @@ -180,6 +180,9 @@ func PodUnderCondition(pod *v1.Pod, condition *v1.PodCondition) bool { func GetNamespaceGuaranteedFromAnnotation(namespaceObj *v1.Namespace) *si.Resource { // retrieve guaranteed resource info from annotations namespaceGuaranteed := GetNameSpaceAnnotationValue(namespaceObj, constants.NamespaceGuaranteed) + if namespaceGuaranteed == "" { + return nil + } var namespaceGuaranteedMap map[string]string err := json.Unmarshal([]byte(namespaceGuaranteed), &namespaceGuaranteedMap) if err != nil { From a686124c180f3fd6cf96f8d40cf75096e25e468a Mon Sep 17 00:00:00 2001 From: haser Date: Fri, 8 Dec 2023 21:28:59 +0800 Subject: [PATCH 2/2] Shortening the variable name and make the code more Go-like, also add coverage. --- pkg/common/utils/utils.go | 23 +++++++++++------------ pkg/common/utils/utils_test.go | 15 +++++++++++++++ 2 files changed, 26 insertions(+), 12 deletions(-) diff --git a/pkg/common/utils/utils.go b/pkg/common/utils/utils.go index c54d6f682..220b68d14 100644 --- a/pkg/common/utils/utils.go +++ b/pkg/common/utils/utils.go @@ -179,19 +179,18 @@ func PodUnderCondition(pod *v1.Pod, condition *v1.PodCondition) bool { // get namespace guaranteed resource from namespace annotation func GetNamespaceGuaranteedFromAnnotation(namespaceObj *v1.Namespace) *si.Resource { // retrieve guaranteed resource info from annotations - namespaceGuaranteed := GetNameSpaceAnnotationValue(namespaceObj, constants.NamespaceGuaranteed) - if namespaceGuaranteed == "" { - return nil - } - var namespaceGuaranteedMap map[string]string - err := json.Unmarshal([]byte(namespaceGuaranteed), &namespaceGuaranteedMap) - if err != nil { - log.Log(log.ShimUtils).Warn("Unable to process namespace.guaranteed annotation", - zap.String("namespace", namespaceObj.Name), - zap.String("namespace.guaranteed is", namespaceGuaranteed)) - return nil + if guaranteed := GetNameSpaceAnnotationValue(namespaceObj, constants.NamespaceGuaranteed); guaranteed != "" { + var namespaceGuaranteedMap map[string]string + err := json.Unmarshal([]byte(guaranteed), &namespaceGuaranteedMap) + if err != nil { + log.Log(log.ShimUtils).Warn("Unable to process namespace.guaranteed annotation", + zap.String("namespace", namespaceObj.Name), + zap.String("namespace.guaranteed is", guaranteed)) + return nil + } + return common.GetResource(namespaceGuaranteedMap) } - return common.GetResource(namespaceGuaranteedMap) + return nil } func GetNamespaceQuotaFromAnnotation(namespaceObj *v1.Namespace) *si.Resource { diff --git a/pkg/common/utils/utils_test.go b/pkg/common/utils/utils_test.go index 77799999c..d7307d3cc 100644 --- a/pkg/common/utils/utils_test.go +++ b/pkg/common/utils/utils_test.go @@ -283,6 +283,21 @@ func TestGetNamespaceGuaranteedFromAnnotation(t *testing.T) { }, }, }, nil}, + {&v1.Namespace{ + ObjectMeta: metav1.ObjectMeta{ + Name: "test", + Namespace: "test", + Annotations: map[string]string{ + constants.NamespaceGuaranteed: "error", + }, + }, + }, nil}, + {&v1.Namespace{ + ObjectMeta: metav1.ObjectMeta{ + Name: "test", + Namespace: "test", + }, + }, nil}, } for _, tc := range testCases { t.Run(fmt.Sprintf("namespace: %v", tc.namespace), func(t *testing.T) {