mirror of
https://github.com/gin-gonic/gin.git
synced 2025-10-16 21:32:11 +08:00
Merge e425b26ceedcc7c952a9a73cc53c9f6d34f15f70 into 44d0dd70924dd154e3b98bc340accc53484efa9c
This commit is contained in:
commit
f92abf1b70
@ -236,7 +236,13 @@ func setWithProperType(val string, value reflect.Value, field reflect.StructFiel
|
|||||||
case time.Time:
|
case time.Time:
|
||||||
return setTimeField(val, field, value)
|
return setTimeField(val, field, value)
|
||||||
}
|
}
|
||||||
return json.Unmarshal(bytesconv.StringToBytes(val), value.Addr().Interface())
|
err1 := json.Unmarshal(bytesconv.StringToBytes(val), value.Addr().Interface())
|
||||||
|
if err1 != nil {
|
||||||
|
if err2 := json.Unmarshal(bytesconv.StringToBytes(strconv.Quote(val)), value.Addr().Interface()); err2 != nil {
|
||||||
|
return fmt.Errorf("%v;tryping to parse with quoted json string but still failed: %v", err1, err2)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
case reflect.Map:
|
case reflect.Map:
|
||||||
return json.Unmarshal(bytesconv.StringToBytes(val), value.Addr().Interface())
|
return json.Unmarshal(bytesconv.StringToBytes(val), value.Addr().Interface())
|
||||||
case reflect.Ptr:
|
case reflect.Ptr:
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
package binding
|
package binding
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"encoding/json"
|
||||||
"reflect"
|
"reflect"
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
@ -199,6 +200,46 @@ func TestMappingTime(t *testing.T) {
|
|||||||
assert.Error(t, err)
|
assert.Error(t, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type CustomDateTime time.Time
|
||||||
|
|
||||||
|
const CustomDateTimeFormat = "2006/01/02 15:04:05"
|
||||||
|
|
||||||
|
func (t CustomDateTime) String() string {
|
||||||
|
return time.Time(t).Format(CustomDateTimeFormat)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *CustomDateTime) UnmarshalJSON(data []byte) error {
|
||||||
|
var value string
|
||||||
|
err := json.Unmarshal(data, &value)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
parseTime, err := time.Parse(CustomDateTimeFormat, value)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
*t = CustomDateTime(parseTime)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestMappingCustomStructFromJsonString(t *testing.T) {
|
||||||
|
var s struct {
|
||||||
|
Time CustomDateTime
|
||||||
|
}
|
||||||
|
value := "2020/09/23 13:20:49"
|
||||||
|
|
||||||
|
// ok
|
||||||
|
err := mappingByPtr(&s, formSource{"Time": {value}}, "form")
|
||||||
|
assert.NoError(t, err)
|
||||||
|
expectedTime, err := time.Parse(CustomDateTimeFormat, value)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.Equal(t, CustomDateTime(expectedTime), s.Time)
|
||||||
|
|
||||||
|
// parse failed
|
||||||
|
err = mappingByPtr(&s, formSource{"Time": {"20200/09/23 13:20:49"}}, "form")
|
||||||
|
assert.Error(t, err)
|
||||||
|
}
|
||||||
|
|
||||||
func TestMappingTimeDuration(t *testing.T) {
|
func TestMappingTimeDuration(t *testing.T) {
|
||||||
var s struct {
|
var s struct {
|
||||||
D time.Duration
|
D time.Duration
|
||||||
|
Loading…
x
Reference in New Issue
Block a user