package xml import ( "reflect" "strings" "testing" ) type Plain struct { V interface{} } type NestedOrder struct { XMLName struct{} `xml:"result"` Field1 string `xml:"parent>c"` Field2 string `xml:"parent>b"` Field3 string `xml:"parent>a"` } func TestCodec_Marshal(t *testing.T) { tests := []struct { Value interface{} ExpectXML string }{ // Test value types {Value: &Plain{true}, ExpectXML: `<Plain><V>true</V></Plain>`}, {Value: &Plain{false}, ExpectXML: `<Plain><V>false</V></Plain>`}, {Value: &Plain{int(42)}, ExpectXML: `<Plain><V>42</V></Plain>`}, { Value: &NestedOrder{Field1: "C", Field2: "B", Field3: "A"}, ExpectXML: `<result>` + `<parent>` + `<c>C</c>` + `<b>B</b>` + `<a>A</a>` + `</parent>` + `</result>`, }, } for _, tt := range tests { data, err := (codec{}).Marshal(tt.Value) if err != nil { t.Errorf("marshal(%#v): %s", tt.Value, err) } if got, want := string(data), tt.ExpectXML; got != want { if strings.Contains(want, "\n") { t.Errorf("marshal(%#v):\nHAVE:\n%s\nWANT:\n%s", tt.Value, got, want) } else { t.Errorf("marshal(%#v):\nhave %#q\nwant %#q", tt.Value, got, want) } } } } func TestCodec_Unmarshal(t *testing.T) { tests := []struct { want interface{} InputXML string }{ { want: &NestedOrder{Field1: "C", Field2: "B", Field3: "A"}, InputXML: `<result>` + `<parent>` + `<c>C</c>` + `<b>B</b>` + `<a>A</a>` + `</parent>` + `</result>`, }, } for _, tt := range tests { vt := reflect.TypeOf(tt.want) dest := reflect.New(vt.Elem()).Interface() data := []byte(tt.InputXML) err := (codec{}).Unmarshal(data, dest) if err != nil { t.Errorf("unmarshal(%#v, %#v): %s", tt.InputXML, dest, err) } if got, want := dest, tt.want; !reflect.DeepEqual(got, want) { t.Errorf("unmarshal(%q):\nhave %#v\nwant %#v", tt.InputXML, got, want) } } } func TestCodec_NilUnmarshal(t *testing.T) { tests := []struct { want interface{} InputXML string }{ { want: &NestedOrder{Field1: "C", Field2: "B", Field3: "A"}, InputXML: `<result>` + `<parent>` + `<c>C</c>` + `<b>B</b>` + `<a>A</a>` + `</parent>` + `</result>`, }, } for _, tt := range tests { s := struct { A string `xml:"a"` B *NestedOrder }{A: "a"} data := []byte(tt.InputXML) err := (codec{}).Unmarshal(data, &s.B) if err != nil { t.Errorf("unmarshal(%#v, %#v): %s", tt.InputXML, s.B, err) } if got, want := s.B, tt.want; !reflect.DeepEqual(got, want) { t.Errorf("unmarshal(%q):\nhave %#v\nwant %#v", tt.InputXML, got, want) } } }