-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathtimeago_test.go
109 lines (92 loc) · 2.8 KB
/
timeago_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
package timeago
import (
"testing"
"time"
"github.com/SerhiiCho/timeago/v3/internal/utils"
)
func TestParseFunctionCanExceptTimestamp(t *testing.T) {
cases := []struct {
date int
res string
}{
{utils.UnixFromPastDate(time.Minute), "1 minute ago"},
{utils.UnixFromPastDate(time.Minute * 5), "5 minutes ago"},
{utils.UnixFromPastDate(time.Hour), "1 hour ago"},
{utils.UnixFromPastDate(time.Hour * 3), "3 hours ago"},
{utils.UnixFromPastDate(time.Hour * 5), "5 hours ago"},
{utils.UnixFromPastDate(time.Hour * 24), "1 day ago"},
{utils.UnixFromPastDate(time.Hour * 24 * 2), "2 days ago"},
{utils.UnixFromPastDate(time.Hour * 24 * 3), "3 days ago"},
{utils.UnixFromPastDate(time.Hour * 24 * 4), "4 days ago"},
{utils.UnixFromPastDate(time.Hour * 24 * 5), "5 days ago"},
{utils.UnixFromPastDate(time.Hour * 24 * 6), "6 days ago"},
{utils.UnixFromPastDate(time.Hour * 24 * 7), "1 week ago"},
}
Reconfigure(Config{Language: LangEn})
for _, tc := range cases {
t.Run(tc.res, func(t *testing.T) {
res, err := Parse(tc.date)
if err != nil {
t.Errorf("Error must be nil, but got %q instead", err)
}
if res != tc.res {
t.Errorf("Result must be %q, but got %q instead", tc.res, res)
}
})
}
}
func TestParseFunctionCanExceptTimePackage(t *testing.T) {
cases := []struct {
date time.Time
res string
}{
{utils.SubMinutes(1), "1 minute ago"},
{utils.SubMinutes(2), "2 minutes ago"},
{utils.SubMinutes(3), "3 minutes ago"},
{utils.SubMinutes(4), "4 minutes ago"},
{utils.SubMinutes(5), "5 minutes ago"},
{utils.SubMinutes(6), "6 minutes ago"},
{utils.SubHours(7), "7 hours ago"},
{utils.SubHours(8), "8 hours ago"},
{utils.SubHours(9), "9 hours ago"},
{utils.SubHours(10), "10 hours ago"},
{utils.SubHours(11), "11 hours ago"},
}
Reconfigure(Config{Language: LangEn})
for _, tc := range cases {
t.Run("Test for date "+tc.date.String(), func(t *testing.T) {
res, err := Parse(tc.date)
if err != nil {
t.Errorf("Error must be nil, but got %q instead", err)
}
if res != tc.res {
t.Errorf("Result must be %q, but got %q instead", tc.res, res)
}
})
}
}
func TestParseFuncWillCalculateIntervalToFutureDate(t *testing.T) {
testCases := []struct {
date time.Time
res string
}{
{utils.AddMinutes(2), "2 minutes"},
{utils.AddMinutes(5), "5 minutes"},
{utils.AddMinutes(10), "10 minutes"},
{utils.AddHours(1), "1 hour"},
{utils.AddHours(24), "1 day"},
{utils.AddHours(48), "2 days"},
}
Reconfigure(Config{Language: LangEn})
for _, tc := range testCases {
t.Run("Test for date: "+tc.date.String(), func(t *testing.T) {
res, err := Parse(tc.date)
if err != nil {
t.Errorf("Error must be nil, but got %q instead", err)
}
if res != tc.res {
t.Errorf("Result must be %q, but got %q instead", tc.res, res)
}
})
}
}