Fix overflow checking when unmarshaling (#388)

Fixes #387
This commit is contained in:
x-hgg-x
2020-05-04 19:22:43 +02:00
committed by GitHub
parent 82a6a1977d
commit 7fbde32684
2 changed files with 29 additions and 3 deletions
+26
View File
@@ -2023,6 +2023,32 @@ func TestUnmarshalCamelCaseKey(t *testing.T) {
}
}
func TestUnmarshalOverflow(t *testing.T) {
type overflow struct {
U8 uint8
I8 int8
F32 float32
}
treeU8, _ := Load("u8 = 300")
treeI8, _ := Load("i8 = 300")
treeF32, _ := Load("f32 = 1e300")
errU8 := treeU8.Unmarshal(&overflow{})
errI8 := treeI8.Unmarshal(&overflow{})
errF32 := treeF32.Unmarshal(&overflow{})
if errU8.Error() != "(1, 1): 300(int64) would overflow uint8" {
t.Error("expect err:(1, 1): 300(int64) would overflow uint8 but got:", errU8)
}
if errI8.Error() != "(1, 1): 300(int64) would overflow int8" {
t.Error("expect err:(1, 1): 300(int64) would overflow int8 but got:", errI8)
}
if errF32.Error() != "(1, 1): 1e+300(float64) would overflow float32" {
t.Error("expect err:(1, 1): 1e+300(float64) would overflow float32 but got:", errF32)
}
}
func TestUnmarshalDefault(t *testing.T) {
type EmbeddedStruct struct {
StringField string `default:"c"`