util: exclude empty label values for crushlocation map

This commit resolves a bug where node labels with empty values
are processed for the crush_location mount option,
leading to invalid mount options and subsequent mount failures.

Signed-off-by: Praveen M <m.praveen@ibm.com>
(cherry picked from commit f11fa815c8)
This commit is contained in:
Praveen M 2024-07-11 18:35:34 +05:30
parent 46e4e3fa82
commit a0af06c9b4
2 changed files with 15 additions and 0 deletions

View File

@ -48,6 +48,10 @@ func getCrushLocationMap(crushLocationLabels string, nodeLabels map[string]strin
// Determine values for requested labels from node labels // Determine values for requested labels from node labels
crushLocationMap := make(map[string]string, len(labelsIn)) crushLocationMap := make(map[string]string, len(labelsIn))
for key, value := range nodeLabels { for key, value := range nodeLabels {
// label with empty value is not considered.
if value == "" {
continue
}
if _, ok := labelsIn[key]; !ok { if _, ok := labelsIn[key]; !ok {
continue continue
} }

View File

@ -100,6 +100,17 @@ func Test_getCrushLocationMap(t *testing.T) {
}, },
want: map[string]string{"host": "worker-1"}, want: map[string]string{"host": "worker-1"},
}, },
{
name: "matching crushlocation and node labels with empty value",
args: input{
crushLocationLabels: "topology.io/region,topology.io/zone",
nodeLabels: map[string]string{
"topology.io/region": "region1",
"topology.io/zone": "",
},
},
want: map[string]string{"region": "region1"},
},
} }
for _, tt := range tests { for _, tt := range tests {
currentTT := tt currentTT := tt