1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
|
package mxj
import (
"fmt"
"testing"
)
func TestXmlCheckIsValid(t *testing.T) {
fmt.Println("================== TestXmlCheckIsValid")
XmlCheckIsValid()
defer XmlCheckIsValid()
data := []byte(`{"":"empty", "$invalid":"hex$", "entities":"<>&", "nil": null}`)
m, err := NewMapJson(data)
if err != nil {
t.Fatal("NewMapJson err;", err)
}
fmt.Printf("%v\n", m)
if _, err = m.Xml(); err == nil {
t.Fatal("Xml err: nil")
}
if _, err = m.XmlIndent("", " "); err == nil {
t.Fatal("XmlIndent err: nil")
}
data = []byte(`{"$invalid":"hex$", "entities":"<>&", "nil": null}`)
m, err = NewMapJson(data)
if err != nil {
t.Fatal("NewMapJson err;", err)
}
fmt.Printf("%v\n", m)
if _, err = m.Xml(); err == nil {
t.Fatal("Xml err: nil")
}
if _, err = m.XmlIndent("", " "); err == nil {
t.Fatal("XmlIndent err: nil")
}
data = []byte(`{"entities":"<>&", "nil": null}`)
m, err = NewMapJson(data)
if err != nil {
t.Fatal("NewMapJson err;", err)
}
fmt.Printf("%v\n", m)
if _, err = m.Xml(); err == nil {
t.Fatal("Xml err: nil")
}
if _, err = m.XmlIndent("", " "); err == nil {
t.Fatal("XmlIndent err: nil")
}
data = []byte(`{"nil": null}`)
m, err = NewMapJson(data)
if err != nil {
t.Fatal("NewMapJson err;", err)
}
fmt.Printf("%v\n", m)
if b, err := m.Xml(); err != nil {
fmt.Println("m:", string(b))
t.Fatal("Xml err:", err)
}
if _, err = m.XmlIndent("", " "); err != nil {
t.Fatal("XmlIndent err:", nil)
}
ms, err := NewMapXmlSeq([]byte(`<doc><elem>element</elem></doc>`))
fmt.Printf("%v\n", ms)
if _, err = ms.Xml(); err != nil {
t.Fatal("Xml err:", err)
}
if _, err = ms.XmlIndent("", " "); err != nil {
t.Fatal("XmlIndent err:", err)
}
}
|