Add support for multiple roots.
parent
722bcb7e7a
commit
98cc243a37
@ -0,0 +1,103 @@
|
|||||||
|
package authority
|
||||||
|
|
||||||
|
import (
|
||||||
|
"reflect"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func Test_multiString_First(t *testing.T) {
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
s multiString
|
||||||
|
want string
|
||||||
|
}{
|
||||||
|
{"empty", multiString{}, ""},
|
||||||
|
{"string", multiString{"one"}, "one"},
|
||||||
|
{"slice", multiString{"one", "two"}, "one"},
|
||||||
|
}
|
||||||
|
for _, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
if got := tt.s.First(); got != tt.want {
|
||||||
|
t.Errorf("multiString.First() = %v, want %v", got, tt.want)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func Test_multiString_Empties(t *testing.T) {
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
s multiString
|
||||||
|
want bool
|
||||||
|
}{
|
||||||
|
{"empty", multiString{}, true},
|
||||||
|
{"string", multiString{"one"}, false},
|
||||||
|
{"empty string", multiString{""}, true},
|
||||||
|
{"slice", multiString{"one", "two"}, false},
|
||||||
|
{"empty slice", multiString{"one", ""}, true},
|
||||||
|
}
|
||||||
|
for _, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
if got := tt.s.Empties(); got != tt.want {
|
||||||
|
t.Errorf("multiString.Empties() = %v, want %v", got, tt.want)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func Test_multiString_MarshalJSON(t *testing.T) {
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
s multiString
|
||||||
|
want []byte
|
||||||
|
wantErr bool
|
||||||
|
}{
|
||||||
|
{"empty", []string{}, []byte(`""`), false},
|
||||||
|
{"string", []string{"a string"}, []byte(`"a string"`), false},
|
||||||
|
{"slice", []string{"string one", "string two"}, []byte(`["string one","string two"]`), false},
|
||||||
|
}
|
||||||
|
for _, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
got, err := tt.s.MarshalJSON()
|
||||||
|
if (err != nil) != tt.wantErr {
|
||||||
|
t.Errorf("multiString.MarshalJSON() error = %v, wantErr %v", err, tt.wantErr)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if !reflect.DeepEqual(got, tt.want) {
|
||||||
|
t.Errorf("multiString.MarshalJSON() = %v, want %v", got, tt.want)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func Test_multiString_UnmarshalJSON(t *testing.T) {
|
||||||
|
|
||||||
|
type args struct {
|
||||||
|
data []byte
|
||||||
|
}
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
s *multiString
|
||||||
|
args args
|
||||||
|
want *multiString
|
||||||
|
wantErr bool
|
||||||
|
}{
|
||||||
|
{"empty", new(multiString), args{[]byte{}}, new(multiString), false},
|
||||||
|
{"empty string", new(multiString), args{[]byte(`""`)}, &multiString{""}, false},
|
||||||
|
{"string", new(multiString), args{[]byte(`"a string"`)}, &multiString{"a string"}, false},
|
||||||
|
{"slice", new(multiString), args{[]byte(`["string one","string two"]`)}, &multiString{"string one", "string two"}, false},
|
||||||
|
{"error", new(multiString), args{[]byte(`["123",123]`)}, new(multiString), true},
|
||||||
|
{"nil", nil, args{nil}, nil, true},
|
||||||
|
}
|
||||||
|
for _, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
if err := tt.s.UnmarshalJSON(tt.args.data); (err != nil) != tt.wantErr {
|
||||||
|
t.Errorf("multiString.UnmarshalJSON() error = %v, wantErr %v", err, tt.wantErr)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if !reflect.DeepEqual(tt.s, tt.want) {
|
||||||
|
t.Errorf("multiString.UnmarshalJSON() = %v, want %v", tt.s, tt.want)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue