mirror of
https://github.com/astaxie/beego.git
synced 2024-11-26 12:51:29 +00:00
Merge branch 'develop' of https://github.com/astaxie/beego into develop
This commit is contained in:
commit
52df1234bd
@ -302,6 +302,14 @@ func ParseForm(form url.Values, obj interface{}) error {
|
|||||||
|
|
||||||
switch fieldT.Type.Kind() {
|
switch fieldT.Type.Kind() {
|
||||||
case reflect.Bool:
|
case reflect.Bool:
|
||||||
|
if strings.ToLower(value) == "on" || strings.ToLower(value) == "1" || strings.ToLower(value) == "yes" {
|
||||||
|
fieldV.SetBool(true)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if strings.ToLower(value) == "off" || strings.ToLower(value) == "0" || strings.ToLower(value) == "no" {
|
||||||
|
fieldV.SetBool(false)
|
||||||
|
continue
|
||||||
|
}
|
||||||
b, err := strconv.ParseBool(value)
|
b, err := strconv.ParseBool(value)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -329,6 +337,19 @@ func ParseForm(form url.Values, obj interface{}) error {
|
|||||||
fieldV.Set(reflect.ValueOf(value))
|
fieldV.Set(reflect.ValueOf(value))
|
||||||
case reflect.String:
|
case reflect.String:
|
||||||
fieldV.SetString(value)
|
fieldV.SetString(value)
|
||||||
|
case reflect.Struct:
|
||||||
|
switch fieldT.Type.String() {
|
||||||
|
case "time.Time":
|
||||||
|
format := time.RFC3339
|
||||||
|
if len(tags) > 1 {
|
||||||
|
format = tags[1]
|
||||||
|
}
|
||||||
|
t, err := time.Parse(format, value)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
fieldV.Set(reflect.ValueOf(t))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
|
@ -108,6 +108,8 @@ func TestParseForm(t *testing.T) {
|
|||||||
Age int `form:"age,text"`
|
Age int `form:"age,text"`
|
||||||
Email string
|
Email string
|
||||||
Intro string `form:",textarea"`
|
Intro string `form:",textarea"`
|
||||||
|
StrBool bool `form:"strbool"`
|
||||||
|
Date time.Time `form:"date,2006-01-02"`
|
||||||
}
|
}
|
||||||
|
|
||||||
u := user{}
|
u := user{}
|
||||||
@ -119,6 +121,8 @@ func TestParseForm(t *testing.T) {
|
|||||||
"age": []string{"40"},
|
"age": []string{"40"},
|
||||||
"Email": []string{"test@gmail.com"},
|
"Email": []string{"test@gmail.com"},
|
||||||
"Intro": []string{"I am an engineer!"},
|
"Intro": []string{"I am an engineer!"},
|
||||||
|
"strbool": []string{"yes"},
|
||||||
|
"date": []string{"2014-11-12"},
|
||||||
}
|
}
|
||||||
if err := ParseForm(form, u); err == nil {
|
if err := ParseForm(form, u); err == nil {
|
||||||
t.Fatal("nothing will be changed")
|
t.Fatal("nothing will be changed")
|
||||||
@ -144,6 +148,13 @@ func TestParseForm(t *testing.T) {
|
|||||||
if u.Intro != "I am an engineer!" {
|
if u.Intro != "I am an engineer!" {
|
||||||
t.Errorf("Intro should equal `I am an engineer!` but got `%v`", u.Intro)
|
t.Errorf("Intro should equal `I am an engineer!` but got `%v`", u.Intro)
|
||||||
}
|
}
|
||||||
|
if u.StrBool != true {
|
||||||
|
t.Errorf("strboll should equal `true`, but got `%v`", u.StrBool)
|
||||||
|
}
|
||||||
|
y, m, d := u.Date.Date()
|
||||||
|
if y != 2014 || m.String() != "November" || d != 12 {
|
||||||
|
t.Errorf("Date should equal `2014-11-12`, but got `%v`", u.Date.String())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestRenderForm(t *testing.T) {
|
func TestRenderForm(t *testing.T) {
|
||||||
|
Loading…
Reference in New Issue
Block a user