package mxj
import (
"fmt"
"testing"
)
var s = `"'<>&`
func TestEscapeChars(t *testing.T) {
fmt.Println("\n================== TestEscapeChars")
ss := escapeChars(s)
if ss != `"'<>&` {
t.Fatal(s, ":", ss)
}
fmt.Println(" s:", s)
fmt.Println("ss:", ss)
}
func TestXMLEscapeChars(t *testing.T) {
fmt.Println("================== TestXMLEscapeChars")
XMLEscapeChars(true)
defer XMLEscapeChars(false)
m := map[string]interface{}{"mychars":s}
x, err := AnyXmlIndent(s, "", " ")
if err != nil {
t.Fatal(err)
}
fmt.Println("s:", string(x))
x, err = AnyXmlIndent(m, "", " ")
if err != nil {
t.Fatal(err)
}
fmt.Println("m:", string(x))
}
func TestXMLEscapeChars2(t *testing.T) {
fmt.Println("================== TestXMLEscapeChars2")
XMLEscapeChars(true)
defer XMLEscapeChars(false)
ss := []byte(`"'<>&`)
fmt.Println(string(ss))
mv, err := NewMapXml(ss)
if err != nil {
t.Fatal(err)
}
fmt.Printf("%v\n", mv)
x, err := mv.XmlIndent("", " ")
if err != nil {
t.Fatal(err)
}
fmt.Println("mv:", string(x))
}
func TestXMLSeqEscapeChars(t *testing.T) {
fmt.Println("================== TestXMLSeqEscapeChars")
data := []byte(`
>0-2y
`)
fmt.Println("data:", string(data))
m, err := NewMapXmlSeq(data)
if err != nil {
t.Fatal(err)
}
fmt.Printf("m: %v\n", m)
XMLEscapeChars(true)
defer XMLEscapeChars(false)
x, err := m.XmlIndent("", " ")
if err != nil {
t.Fatal(err)
}
fmt.Println("m:", string(x))
}
func TestXMLSeqEscapeChars2(t *testing.T) {
fmt.Println("================== TestXMLSeqEscapeChars2")
data := []byte(`
>0-2y
<10-15
`)
fmt.Println("data:", string(data))
m, err := NewMapXmlSeq(data)
if err != nil {
t.Fatal(err)
}
fmt.Printf("m: %v\n", m)
XMLEscapeChars(true)
defer XMLEscapeChars(false)
x, err := m.XmlIndent("", " ")
if err != nil {
t.Fatal(err)
}
fmt.Println("m:", string(x))
}