forked from TrueCloudLab/restic
Don't crash if SecretString is uninitialized
This commit is contained in:
parent
bb5f196b09
commit
cdaf9b4f26
2 changed files with 12 additions and 1 deletions
|
@ -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
|
||||
}
|
||||
|
|
|
@ -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())
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue