forked from clbanning/mxj
-
Notifications
You must be signed in to change notification settings - Fork 0
/
cast_test.go
80 lines (69 loc) · 1.53 KB
/
cast_test.go
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)
}