Don't crash if SecretString is uninitialized

This commit is contained in:
Michael Eischer 2022-07-02 19:44:28 +02:00
parent bb5f196b09
commit cdaf9b4f26
2 changed files with 12 additions and 1 deletions

View File

@ -13,12 +13,15 @@ func (s SecretString) GoString() string {
}
func (s SecretString) String() string {
if len(*s.s) == 0 {
if s.s == nil || len(*s.s) == 0 {
return ``
}
return `**redacted**`
}
func (s *SecretString) Unwrap() string {
if s.s == nil {
return ""
}
return *s.s
}

View File

@ -53,3 +53,11 @@ func TestSecretStringEmpty(t *testing.T) {
test.Equals(t, `""`, fmt.Sprintf("%#v", secret))
test.Equals(t, keyStr, secret.Unwrap())
}
func TestSecretStringDefault(t *testing.T) {
secretStruct := &secretTest{}
test.Equals(t, "", secretStruct.str.String())
test.Equals(t, `""`, secretStruct.str.GoString())
test.Equals(t, "", secretStruct.str.Unwrap())
}