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 76 77 78 79 80
|
package mxj
import (
"fmt"
"testing"
)
var castdata = []byte(`<doc>
<string>string</string>
<float>3.14159625</float>
<int>2019</int>
<bool>
<true>true</true>
<false>FALSE</false>
<T>T</T>
<f>f</f>
</bool></doc>`)
func TestHeader(t *testing.T) {
fmt.Println("\ncast_test.go ----------")
}
func TestCastDefault(t *testing.T) {
fmt.Println("------------ TestCastDefault ...")
m, err := NewMapXml(castdata)
if err != nil {
t.Fatal(err.Error())
}
fmt.Printf("%#v\n", m)
}
func TestCastTrue(t *testing.T) {
fmt.Println("------------ TestCastTrue ...")
m, _ := NewMapXml(castdata, true)
fmt.Printf("%#v\n", m)
}
func TestSetCheckTagToSkipFunc(t *testing.T) {
fmt.Println("------------ TestSetCheckTagToSkipFunc ...")
fn := func(tag string) bool {
list := []string{"int","false"}
for _, v := range list {
if v == tag {
return true
}
}
return false
}
SetCheckTagToSkipFunc(fn)
m, err := NewMapXml(castdata, true)
if err != nil {
t.Fatal(err.Error())
}
fmt.Printf("%#v\n", m)
}
func TestCastValuesToFloat(t *testing.T) {
fmt.Println("------------ TestCastValuesToFloat(false) ...")
CastValuesToFloat(false)
defer CastValuesToFloat(true)
m, err := NewMapXml(castdata, true)
if err != nil {
t.Fatal(err.Error())
}
fmt.Printf("%#v\n", m)
}
func TestCastValuesToBool(t *testing.T) {
fmt.Println("------------ TestCastValuesToBool(false) ...")
CastValuesToBool(false)
defer CastValuesToBool(true)
m, err := NewMapXml(castdata, true)
if err != nil {
t.Fatal(err.Error())
}
fmt.Printf("%#v\n", m)
}
|