From 6f0f340bce0f4e9123cd1a543ed5440e7fda8d80 Mon Sep 17 00:00:00 2001 From: Luca Popesco Date: Wed, 19 May 2021 12:47:28 -0400 Subject: [PATCH 1/2] Remove acr validator from scopemaps --- .../containers/container_registry_scope_map_resource.go | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/azurerm/internal/services/containers/container_registry_scope_map_resource.go b/azurerm/internal/services/containers/container_registry_scope_map_resource.go index 3de73d874b13..0ebc973eb89f 100644 --- a/azurerm/internal/services/containers/container_registry_scope_map_resource.go +++ b/azurerm/internal/services/containers/container_registry_scope_map_resource.go @@ -37,10 +37,9 @@ func resourceContainerRegistryScopeMap() *schema.Resource { Schema: map[string]*schema.Schema{ "name": { - Type: schema.TypeString, - Required: true, - ForceNew: true, - ValidateFunc: validate.ContainerRegistryName, + Type: schema.TypeString, + Required: true, + ForceNew: true, }, "description": { From 3eaba7f82c9cfbc74bd331f15e4384c775653005 Mon Sep 17 00:00:00 2001 From: Luca Popesco Date: Wed, 19 May 2021 14:20:41 -0400 Subject: [PATCH 2/2] Add validator for acr scope maps --- .../container_registry_scope_map_resource.go | 7 +- .../container_registry_scope_map_name.go | 24 +++++++ .../container_registry_scope_map_name_test.go | 68 +++++++++++++++++++ 3 files changed, 96 insertions(+), 3 deletions(-) create mode 100644 azurerm/internal/services/containers/validate/container_registry_scope_map_name.go create mode 100644 azurerm/internal/services/containers/validate/container_registry_scope_map_name_test.go diff --git a/azurerm/internal/services/containers/container_registry_scope_map_resource.go b/azurerm/internal/services/containers/container_registry_scope_map_resource.go index 0ebc973eb89f..9442aa4590f7 100644 --- a/azurerm/internal/services/containers/container_registry_scope_map_resource.go +++ b/azurerm/internal/services/containers/container_registry_scope_map_resource.go @@ -37,9 +37,10 @@ func resourceContainerRegistryScopeMap() *schema.Resource { Schema: map[string]*schema.Schema{ "name": { - Type: schema.TypeString, - Required: true, - ForceNew: true, + Type: schema.TypeString, + Required: true, + ForceNew: true, + ValidateFunc: validate.ContainerRegistryScopeMapName, }, "description": { diff --git a/azurerm/internal/services/containers/validate/container_registry_scope_map_name.go b/azurerm/internal/services/containers/validate/container_registry_scope_map_name.go new file mode 100644 index 000000000000..2a35b0c2989d --- /dev/null +++ b/azurerm/internal/services/containers/validate/container_registry_scope_map_name.go @@ -0,0 +1,24 @@ +package validate + +import ( + "fmt" + "regexp" +) + +func ContainerRegistryScopeMapName(v interface{}, k string) (warnings []string, errors []error) { + value := v.(string) + if !regexp.MustCompile(`^[a-zA-Z0-9\-]+$`).MatchString(value) { + errors = append(errors, fmt.Errorf( + "alpha numeric characters and hyphens only are allowed in %q: %q", k, value)) + } + + if 5 > len(value) { + errors = append(errors, fmt.Errorf("%q cannot be less than 5 characters: %q", k, value)) + } + + if len(value) >= 50 { + errors = append(errors, fmt.Errorf("%q cannot be longer than 50 characters: %q %d", k, value, len(value))) + } + + return warnings, errors +} diff --git a/azurerm/internal/services/containers/validate/container_registry_scope_map_name_test.go b/azurerm/internal/services/containers/validate/container_registry_scope_map_name_test.go new file mode 100644 index 000000000000..234364a1f67a --- /dev/null +++ b/azurerm/internal/services/containers/validate/container_registry_scope_map_name_test.go @@ -0,0 +1,68 @@ +package validate_test + +import ( + "testing" + + "github.com/terraform-providers/terraform-provider-azurerm/azurerm/internal/services/containers/validate" +) + +func TestContainerRegistryScopeMapName(t *testing.T) { + cases := []struct { + Value string + ErrCount int + }{ + { + Value: "four", + ErrCount: 1, + }, + { + Value: "5five", + ErrCount: 0, + }, + { + Value: "five-123", + ErrCount: 0, + }, + { + Value: "hello-world", + ErrCount: 0, + }, + { + Value: "hello_world", + ErrCount: 1, + }, + { + Value: "helloWorld", + ErrCount: 0, + }, + { + Value: "helloworld12", + ErrCount: 0, + }, + { + Value: "hello@world", + ErrCount: 1, + }, + + { + Value: "qfvbdsbvipqdbwsbddbdcwqffewsqwcdw21ddwqwd3324120", + ErrCount: 0, + }, + { + Value: "qfvbdsbvipqdbwsbddbdcwqffewsqwcdw21ddwqwd33241202", + ErrCount: 0, + }, + { + Value: "qfvbdsbvipqdbwsbddbdcwqfjjfewsqwcdw21ddwqwd3324120fadfadf", + ErrCount: 1, + }, + } + + for _, tc := range cases { + _, errors := validate.ContainerRegistryScopeMapName(tc.Value, "azurerm_container_registry_scope_map") + + if len(errors) != tc.ErrCount { + t.Fatalf("Expected the Azure RM Container Registry Token Name to trigger a validation error: %v", errors) + } + } +}