forked from dromara/carbon
-
Notifications
You must be signed in to change notification settings - Fork 0
/
parser_test.go
executable file
·113 lines (97 loc) · 3.51 KB
/
parser_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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
package carbon
import (
"testing"
)
func TestCarbon_Parse(t *testing.T) {
Tests := []struct {
input string // 输入值
output string // 期望输出值
}{
{"", ""},
{"0", ""},
{"0000-00-00", ""},
{"0000-00-00 00:00:00", ""},
{"2020-08-05 13:14:15", "2020-08-05 13:14:15"},
{"20200805131415", "2020-08-05 13:14:15"},
{"20200805", "2020-08-05 00:00:00"},
{"2020-08-05", "2020-08-05 00:00:00"},
{"2020-08-05T13:14:15+08:00", "2020-08-05 13:14:15"},
{"12345678", ""}, // 异常情况
}
for _, v := range Tests {
output := Parse(v.input)
if output.Error != nil {
t.Logf("catch an exception in Parse():%v", output.Error)
} else if output.ToDateTimeString() != v.output {
t.Errorf("Input %s, expected %s, but got %s\n", v.input, v.output, output.ToDateTimeString())
}
}
for _, v := range Tests {
output := SetTimezone(PRC).Parse(v.input)
if output.Error != nil {
t.Logf("catch an exception in Parse():%v", output.Error)
} else if output.ToDateTimeString() != v.output {
t.Errorf("Input %s, expected %s, but got %s\n", v.input, v.output, output.ToDateTimeString())
}
}
}
var ParseByFormatTests = []struct {
input string // 输入值
format string // 输入参数
output string // 期望输出值
}{
{"2020|08|05 13:14:15", "Y|m|d H:i:s", "2020-08-05 13:14:15"},
{"It is 2020|08|05 13:14:15", "It is Y|m|d H:i:s", "2020-08-05 13:14:15"},
{"今天是 2020年08月05日13时14分15秒", "今天是 Y年m月d日H时i分s秒", "2020-08-05 13:14:15"},
{"12345678", "XXXX", ""}, // 异常情况
}
func TestCarbon_ParseByFormat1(t *testing.T) {
for _, v := range ParseByFormatTests {
output := ParseByFormat(v.input, v.format)
if output.Error != nil {
t.Logf("catch an exception in ParseByFormat():%v", output.Error)
} else if output.ToDateTimeString() != v.output {
t.Errorf("Input %s, expected %s, but got %s\n", v.input, v.output, output.ToDateTimeString())
}
}
}
func TestCarbon_ParseByFormat2(t *testing.T) {
for _, v := range ParseByFormatTests {
output := SetTimezone("XXXX").ParseByFormat(v.input, v.format)
if output.Error != nil {
t.Logf("catch an exception in ParseByFormat():%v", output.Error)
} else if output.ToDateTimeString() != v.output {
t.Errorf("Input %s, expected %s, but got %s\n", v.input, v.output, output.ToDateTimeString())
}
}
}
var ParseByLayoutTests = []struct {
input string // 输入值
format string // 输入参数
output string // 期望输出值
}{
{"2020|08|05 13:14:15", "2006|01|02 15:04:05", "2020-08-05 13:14:15"},
{"It is 2020|08|05 13:14:15", "It is 2006|01|02 15:04:05", "2020-08-05 13:14:15"},
{"今天是 2020年08月05日13时14分15秒", "今天是 2006年01月02日15时04分05秒", "2020-08-05 13:14:15"},
{"12345678", "XXXX", ""}, // 异常情况
}
func TestCarbon_ParseByLayout1(t *testing.T) {
for _, v := range ParseByLayoutTests {
output := ParseByLayout(v.input, v.format)
if output.Error != nil {
t.Logf("catch an exception in ParseByLayout():%v", output.Error)
} else if output.ToDateTimeString() != v.output {
t.Errorf("Input %s, expected %s, but got %s\n", v.input, v.output, output.ToDateTimeString())
}
}
}
func TestCarbon_ParseByLayout2(t *testing.T) {
for _, v := range ParseByLayoutTests {
output := SetTimezone("XXXX").ParseByLayout(v.input, v.format)
if output.Error != nil {
t.Logf("catch an exception in ParseByLayout():%v", output.Error)
} else if output.ToDateTimeString() != v.output {
t.Errorf("Input %s, expected %s, but got %s\n", v.input, v.output, output.ToDateTimeString())
}
}
}