Skip to content

Commit

Permalink
wip
Browse files Browse the repository at this point in the history
  • Loading branch information
sfc-gh-jcieslak committed Feb 27, 2024
1 parent d910a84 commit 4d731f5
Show file tree
Hide file tree
Showing 3 changed files with 89 additions and 46 deletions.
43 changes: 43 additions & 0 deletions pkg/resources/grant_privileges_to_account_role_acceptance_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -929,6 +929,49 @@ func TestAcc_GrantPrivilegesToAccountRole_ImportedPrivileges(t *testing.T) {
})
}

func TestAcc_GrantPrivilegesToAccountRole_MultiplePartsInRoleName(t *testing.T) {
nameBytes := []byte(strings.ToUpper(acctest.RandStringFromCharSet(10, acctest.CharSetAlpha)))
nameBytes[3] = '.'
nameBytes[6] = '.'
name := string(nameBytes)
roleName := sdk.NewAccountObjectIdentifier(name).FullyQualifiedName()
configVariables := config.Variables{
"name": config.StringVariable(roleName),
"privileges": config.ListVariable(
config.StringVariable(string(sdk.GlobalPrivilegeCreateDatabase)),
config.StringVariable(string(sdk.GlobalPrivilegeCreateRole)),
),
"with_grant_option": config.BoolVariable(true),
}
resourceName := "snowflake_grant_privileges_to_account_role.test"

resource.Test(t, resource.TestCase{
ProtoV6ProviderFactories: acc.TestAccProtoV6ProviderFactories,
PreCheck: func() { acc.TestAccPreCheck(t) },
TerraformVersionChecks: []tfversion.TerraformVersionCheck{
tfversion.RequireAbove(tfversion.Version1_5_0),
},
CheckDestroy: testAccCheckAccountRolePrivilegesRevoked(name),
Steps: []resource.TestStep{
{
PreConfig: func() { createAccountRoleOutsideTerraform(t, name) },
ConfigDirectory: acc.ConfigurationDirectory("TestAcc_GrantPrivilegesToAccountRole/OnAccount"),
ConfigVariables: configVariables,
Check: resource.ComposeTestCheckFunc(
resource.TestCheckResourceAttr(resourceName, "account_role_name", roleName),
),
},
{
ConfigDirectory: acc.ConfigurationDirectory("TestAcc_GrantPrivilegesToAccountRole/OnAccount"),
ConfigVariables: configVariables,
ResourceName: resourceName,
ImportState: true,
ImportStateVerify: true,
},
},
})
}

func getSecondaryAccountName(t *testing.T) (string, error) {
t.Helper()
config, err := sdk.ProfileConfig(testprofiles.Secondary)
Expand Down
75 changes: 41 additions & 34 deletions pkg/resources/validators.go
Original file line number Diff line number Diff line change
Expand Up @@ -40,51 +40,58 @@ func IsDataType() schema.SchemaValidateFunc { //nolint:staticcheck
// To use this function, pass it as a validation function on identifier field with generic parameter set to the desired sdk.ObjectIdentifier implementation.
func IsValidIdentifier[T sdk.AccountObjectIdentifier | sdk.DatabaseObjectIdentifier | sdk.SchemaObjectIdentifier | sdk.TableColumnIdentifier]() schema.SchemaValidateDiagFunc {
return func(value any, path cty.Path) diag.Diagnostics {
var diags diag.Diagnostics

if _, ok := value.(string); !ok {
diags = append(diags, diag.Diagnostic{
Severity: diag.Error,
Summary: "Invalid schema identifier type",
Detail: fmt.Sprintf("Expected schema string type, but got: %T. This is a provider error please file a report: https://github.com/Snowflake-Labs/terraform-provider-snowflake/issues/new/choose", value),
AttributePath: path,
})
return diags
return diag.Diagnostics{
diag.Diagnostic{
Severity: diag.Error,
Summary: "Invalid schema identifier type",
Detail: fmt.Sprintf("Expected schema string type, but got: %T. This is a provider error please file a report: https://github.com/Snowflake-Labs/terraform-provider-snowflake/issues/new/choose", value),
AttributePath: path,
},
}
}

// TODO(SNOW-1163071): Right now we have to skip validation for AccountObjectIdentifier to handle a case where identifier contains dots
if _, ok := any(sdk.AccountObjectIdentifier{}).(T); ok {
return nil
}

stringValue := value.(string)
id, err := helpers.DecodeSnowflakeParameterID(stringValue)
if err != nil {
diags = append(diags, diag.Diagnostic{
Severity: diag.Error,
Summary: "Unable to parse the identifier",
Detail: fmt.Sprintf(
"Unable to parse the identifier: %s. Make sure you are using the correct form of the fully qualified name for this field: %s.\nOriginal Error: %s",
stringValue,
getExpectedIdentifierRepresentationFromGeneric[T](),
err.Error(),
),
AttributePath: path,
})
return diags
return diag.Diagnostics{
diag.Diagnostic{
Severity: diag.Error,
Summary: "Unable to parse the identifier",
Detail: fmt.Sprintf(
"Unable to parse the identifier: %s. Make sure you are using the correct form of the fully qualified name for this field: %s.\nOriginal Error: %s",
stringValue,
getExpectedIdentifierRepresentationFromGeneric[T](),
err.Error(),
),
AttributePath: path,
},
}
}

if _, ok := id.(T); !ok {
diags = append(diags, diag.Diagnostic{
Severity: diag.Error,
Summary: "Invalid identifier type",
Detail: fmt.Sprintf(
"Expected %s identifier type, but got: %T. The correct form of the fully qualified name for this field is: %s, but was %s",
reflect.TypeOf(new(T)).Elem().Name(),
id,
getExpectedIdentifierRepresentationFromGeneric[T](),
getExpectedIdentifierRepresentationFromParam(id),
),
AttributePath: path,
})
return diag.Diagnostics{
diag.Diagnostic{
Severity: diag.Error,
Summary: "Invalid identifier type",
Detail: fmt.Sprintf(
"Expected %s identifier type, but got: %T. The correct form of the fully qualified name for this field is: %s, but was %s",
reflect.TypeOf(new(T)).Elem().Name(),
id,
getExpectedIdentifierRepresentationFromGeneric[T](),
getExpectedIdentifierRepresentationFromParam(id),
),
AttributePath: path,
},
}
}

return diags
return nil
}
}

Expand Down
17 changes: 5 additions & 12 deletions pkg/resources/validators_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -69,18 +69,6 @@ func TestIsValidIdentifier(t *testing.T) {
Error: "Expected schema string type, but got: int",
CheckingFn: accountObjectIdentifierCheck,
},
{
Name: "validation: invalid identifier representation",
Value: "",
Error: "Unable to parse the identifier: ",
CheckingFn: accountObjectIdentifierCheck,
},
{
Name: "validation: incorrect form for account object identifier",
Value: "a.b",
Error: "<name>, but was <database_name>.<name>",
CheckingFn: accountObjectIdentifierCheck,
},
{
Name: "validation: incorrect form for database object identifier",
Value: "a.b.c",
Expand All @@ -104,6 +92,11 @@ func TestIsValidIdentifier(t *testing.T) {
Value: "a",
CheckingFn: accountObjectIdentifierCheck,
},
{
Name: "correct form for account object identifier - multiple parts",
Value: "a.b",
CheckingFn: accountObjectIdentifierCheck,
},
{
Name: "correct form for database object identifier",
Value: "a.b",
Expand Down

0 comments on commit 4d731f5

Please sign in to comment.