Passed
Pull Request — main (#40)
by Serhii
01:18
created

tests.TestParseNl   B

Complexity

Conditions 5

Size

Total Lines 62
Code Lines 55

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 5
eloc 55
dl 0
loc 62
rs 8.006
c 0
b 0
f 0
nop 1

How to fix   Long Method   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

1
package tests
2
3
import (
4
	"testing"
5
	"time"
6
7
	"github.com/SerhiiCho/timeago/v3"
8
)
9
10
const langNl = "nl"
11
12
func TestParseNl(t *testing.T) {
13
	cases := []struct {
14
		date time.Time
15
		res  string
16
	}{
17
		{subMinutes(1), "1 minuut geleden"},
18
		{subMinutes(2), "2 minuten geleden"},
19
		{subMinutes(5), "5 minuten geleden"},
20
		{subMinutes(9), "9 minuten geleden"},
21
		{subMinutes(10), "10 minuten geleden"},
22
		{subMinutes(11), "11 minuten geleden"},
23
		{subMinutes(20), "20 minuten geleden"},
24
		{subMinutes(21), "21 minuten geleden"},
25
		{subMinutes(22), "22 minuten geleden"},
26
		{subMinutes(30), "30 minuten geleden"},
27
		{subMinutes(31), "31 minuten geleden"},
28
		{subMinutes(59), "59 minuten geleden"},
29
		{subMinutes(60), "1 uur geleden"},
30
		{subHours(1), "1 uur geleden"},
31
		{subHours(2), "2 uur geleden"},
32
		{subHours(9), "9 uur geleden"},
33
		{subHours(10), "10 uur geleden"},
34
		{subHours(11), "11 uur geleden"},
35
		{subHours(20), "20 uur geleden"},
36
		{subHours(21), "21 uur geleden"},
37
		{subHours(23), "23 uur geleden"},
38
		{subDays(1), "1 dag geleden"},
39
		{subDays(2), "2 dagen geleden"},
40
		{subDays(6), "6 dagen geleden"},
41
		{subWeeks(1), "1 week geleden"},
42
		{subWeeks(2), "2 weken geleden"},
43
		{subWeeks(3), "3 weken geleden"},
44
		{subMonths(1), "1 maand geleden"},
45
		{subMonths(2), "2 maanden geleden"},
46
		{subMonths(3), "3 maanden geleden"},
47
		{subMonths(4), "4 maanden geleden"},
48
		{subMonths(5), "5 maanden geleden"},
49
		{subMonths(6), "6 maanden geleden"},
50
		{subMonths(7), "7 maanden geleden"},
51
		{subMonths(8), "8 maanden geleden"},
52
		{subMonths(9), "9 maanden geleden"},
53
		{subMonths(10), "10 maanden geleden"},
54
		{subMonths(11), "11 maanden geleden"},
55
		{subYears(1), "1 jaar geleden"},
56
		{subYears(2), "2 jaar geleden"},
57
		{subYears(21), "21 jaar geleden"},
58
		{subYears(31), "31 jaar geleden"},
59
		{subYears(100), "100 jaar geleden"},
60
	}
61
62
	for _, tc := range cases {
63
		t.Run("result for "+tc.date.String(), func(test *testing.T) {
64
			timeago.Reconfigure(timeago.Config{Language: langNl})
65
66
			res, err := timeago.Parse(tc.date)
67
68
			if err != nil {
69
				test.Errorf("Error must be nil, but got %v instead", err)
70
			}
71
72
			if res != tc.res {
73
				test.Errorf("Result must be %s, but got %s instead", tc.res, res)
74
			}
75
		})
76
	}
77
}
78
79
func TestParseNlWithSeconds(t *testing.T) {
80
	cases := []struct {
81
		date time.Time
82
		res  []string
83
	}{
84
		{subSeconds(0), []string{"0 seconden geleden", "1 seconde geleden"}},
85
		{subSeconds(1), []string{"1 seconde geleden", "2 seconden geleden"}},
86
		{subSeconds(2), []string{"2 seconden geleden", "3 seconden geleden"}},
87
		{subSeconds(9), []string{"9 seconden geleden", "10 seconden geleden"}},
88
		{subSeconds(10), []string{"10 seconden geleden", "11 seconden geleden"}},
89
		{subSeconds(11), []string{"11 seconden geleden", "12 seconden geleden"}},
90
		{subSeconds(20), []string{"20 seconden geleden", "21 seconden geleden"}},
91
		{subSeconds(21), []string{"21 seconden geleden", "22 seconden geleden"}},
92
		{subSeconds(22), []string{"22 seconden geleden", "23 seconden geleden"}},
93
		{subSeconds(30), []string{"30 seconden geleden", "31 seconden geleden"}},
94
		{subSeconds(31), []string{"31 seconden geleden", "32 seconden geleden"}},
95
		{subSeconds(59), []string{"59 seconden geleden", "1 minuten geleden"}},
96
	}
97
98
	for _, tc := range cases {
99
		t.Run("result for "+tc.date.String(), func(test *testing.T) {
100
			timeago.Reconfigure(timeago.Config{Language: langNl})
101
102
			res, err := timeago.Parse(tc.date)
103
104
			if err != nil {
105
				test.Errorf("Error must be nil, but got %v instead", err)
106
			}
107
108
			if res != tc.res[0] && res != tc.res[1] {
109
				test.Errorf("Result must be %s or %s, but got %s instead", tc.res[0], tc.res[1], res)
110
			}
111
		})
112
	}
113
}
114