From 3e53369e17d0878d10a41261d7360da25e4c1885 Mon Sep 17 00:00:00 2001 From: Marwan Ahmed Date: Tue, 4 May 2021 22:31:07 -0700 Subject: [PATCH] support separators in custom allocatable overrides via vmss tags --- cluster-autoscaler/cloudprovider/azure/azure_template.go | 3 ++- .../cloudprovider/azure/azure_template_test.go | 9 ++++++--- 2 files changed, 8 insertions(+), 4 deletions(-) diff --git a/cluster-autoscaler/cloudprovider/azure/azure_template.go b/cluster-autoscaler/cloudprovider/azure/azure_template.go index eb931f31c3a0..89c1f7017f62 100644 --- a/cluster-autoscaler/cloudprovider/azure/azure_template.go +++ b/cluster-autoscaler/cloudprovider/azure/azure_template.go @@ -196,11 +196,12 @@ func extractAllocatableResourcesFromScaleSet(tags map[string]*string) map[string continue } + normalizedResourceName := strings.Replace(resourceName[1], "_", "/", -1) quantity, err := resource.ParseQuantity(*tagValue) if err != nil { continue } - resources[resourceName[1]] = &quantity + resources[normalizedResourceName] = &quantity } return resources diff --git a/cluster-autoscaler/cloudprovider/azure/azure_template_test.go b/cluster-autoscaler/cloudprovider/azure/azure_template_test.go index 3ee23080eccd..5049f7cb5979 100644 --- a/cluster-autoscaler/cloudprovider/azure/azure_template_test.go +++ b/cluster-autoscaler/cloudprovider/azure/azure_template_test.go @@ -90,9 +90,10 @@ func TestExtractTaintsFromScaleSet(t *testing.T) { func TestExtractAllocatableResourcesFromScaleSet(t *testing.T) { tags := map[string]*string{ - fmt.Sprintf("%s%s", nodeResourcesTagName, "cpu"): to.StringPtr("100m"), - fmt.Sprintf("%s%s", nodeResourcesTagName, "memory"): to.StringPtr("100M"), - fmt.Sprintf("%s%s", nodeResourcesTagName, "ephemeral-storage"): to.StringPtr("20G"), + fmt.Sprintf("%s%s", nodeResourcesTagName, "cpu"): to.StringPtr("100m"), + fmt.Sprintf("%s%s", nodeResourcesTagName, "memory"): to.StringPtr("100M"), + fmt.Sprintf("%s%s", nodeResourcesTagName, "ephemeral-storage"): to.StringPtr("20G"), + fmt.Sprintf("%s%s", nodeResourcesTagName, "nvidia.com_Tesla-P100-PCIE"): to.StringPtr("4"), } labels := extractAllocatableResourcesFromScaleSet(tags) @@ -102,6 +103,8 @@ func TestExtractAllocatableResourcesFromScaleSet(t *testing.T) { assert.Equal(t, (&expectedMemory).String(), labels["memory"].String()) expectedEphemeralStorage := resource.MustParse("20G") assert.Equal(t, (&expectedEphemeralStorage).String(), labels["ephemeral-storage"].String()) + exepectedCustomAllocatable := resource.MustParse("4") + assert.Equal(t, (&exepectedCustomAllocatable).String(), labels["nvidia.com/Tesla-P100-PCIE"].String()) } func makeTaintSet(taints []apiv1.Taint) map[apiv1.Taint]bool {