Skip to content

Commit

Permalink
helper/validation: StringInSlice: Single quote slice elements (#1237)
Browse files Browse the repository at this point in the history
The validation function's error is ambiguous when dealing with slices
containing spaces. For example:
```
expected role_name to be one of [Apache Spark Administrator Synapse Credential User Synapse Administrator]
```

By changing the format verb, the error becomes more user friendly:
```
expected role_name to be one of ["Apache Spark Administrator" "Synapse Credential User" "Synapse Administrator"]
```

This fixes #464

Signed-off-by: Frank Villaro-Dixon <[email protected]>
  • Loading branch information
Frankkkkk authored Aug 29, 2023
1 parent 49fb1ee commit 09a29d6
Show file tree
Hide file tree
Showing 3 changed files with 9 additions and 3 deletions.
6 changes: 6 additions & 0 deletions .changes/unreleased/ENHANCEMENTS-20230829-141309.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
kind: ENHANCEMENTS
body: 'helper/validation: Added quoting in `StringInSlice` error diagnostic output to
prevent confusion with values that contain spaces'
time: 2023-08-29T14:13:09.735543+02:00
custom:
Issue: "464"
2 changes: 1 addition & 1 deletion helper/validation/strings.go
Original file line number Diff line number Diff line change
Expand Up @@ -146,7 +146,7 @@ func StringInSlice(valid []string, ignoreCase bool) schema.SchemaValidateFunc {
}
}

errors = append(errors, fmt.Errorf("expected %s to be one of %v, got %s", k, valid, v))
errors = append(errors, fmt.Errorf("expected %s to be one of %q, got %s", k, valid, v))
return warnings, errors
}
}
Expand Down
4 changes: 2 additions & 2 deletions helper/validation/strings_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -293,12 +293,12 @@ func TestValidationStringInSlice(t *testing.T) {
{
val: "VALIDVALUE",
f: StringInSlice([]string{"ValidValue", "AnotherValidValue"}, false),
expectedErr: regexp.MustCompile(`expected [\w]+ to be one of \[ValidValue AnotherValidValue\], got VALIDVALUE`),
expectedErr: regexp.MustCompile(`expected [\w]+ to be one of \["ValidValue" "AnotherValidValue"\], got VALIDVALUE`),
},
{
val: "InvalidValue",
f: StringInSlice([]string{"ValidValue", "AnotherValidValue"}, false),
expectedErr: regexp.MustCompile(`expected [\w]+ to be one of \[ValidValue AnotherValidValue\], got InvalidValue`),
expectedErr: regexp.MustCompile(`expected [\w]+ to be one of \["ValidValue" "AnotherValidValue"\], got InvalidValue`),
},
{
val: 1,
Expand Down

0 comments on commit 09a29d6

Please sign in to comment.