]>
Commit | Line | Data |
---|---|---|
34dc6e73 JK |
1 | #!/bin/sh |
2 | ||
3 | test_description='test date parsing and printing' | |
4 | . ./test-lib.sh | |
5 | ||
6 | # arbitrary reference time: 2009-08-30 19:20:00 | |
b841d4ff | 7 | GIT_TEST_DATE_NOW=1251660000; export GIT_TEST_DATE_NOW |
34dc6e73 | 8 | |
fdba2cde | 9 | check_relative() { |
b841d4ff | 10 | t=$(($GIT_TEST_DATE_NOW - $1)) |
34dc6e73 JK |
11 | echo "$t -> $2" >expect |
12 | test_expect_${3:-success} "relative date ($2)" " | |
a801a7cf | 13 | test-tool date relative $t >actual && |
4fa7e198 | 14 | test_i18ncmp expect actual |
34dc6e73 JK |
15 | " |
16 | } | |
17 | ||
fdba2cde JK |
18 | check_relative 5 '5 seconds ago' |
19 | check_relative 300 '5 minutes ago' | |
20 | check_relative 18000 '5 hours ago' | |
21 | check_relative 432000 '5 days ago' | |
22 | check_relative 1728000 '3 weeks ago' | |
23 | check_relative 13000000 '5 months ago' | |
24 | check_relative 37500000 '1 year, 2 months ago' | |
25 | check_relative 55188000 '1 year, 9 months ago' | |
26 | check_relative 630000000 '20 years ago' | |
27 | check_relative 31449600 '12 months ago' | |
28 | check_relative 62985600 '2 years ago' | |
34dc6e73 | 29 | |
36d67921 JK |
30 | check_show () { |
31 | format=$1 | |
32 | time=$2 | |
33 | expect=$3 | |
22280d7e JK |
34 | prereqs=$4 |
35 | zone=$5 | |
36 | test_expect_success $prereqs "show date ($format:$time)" ' | |
36d67921 | 37 | echo "$time -> $expect" >expect && |
a801a7cf | 38 | TZ=${zone:-$TZ} test-tool date show:"$format" "$time" >actual && |
36d67921 JK |
39 | test_cmp expect actual |
40 | ' | |
41 | } | |
42 | ||
43 | # arbitrary but sensible time for examples | |
44 | TIME='1466000000 +0200' | |
45 | check_show iso8601 "$TIME" '2016-06-15 16:13:20 +0200' | |
46 | check_show iso8601-strict "$TIME" '2016-06-15T16:13:20+02:00' | |
47 | check_show rfc2822 "$TIME" 'Wed, 15 Jun 2016 16:13:20 +0200' | |
48 | check_show short "$TIME" '2016-06-15' | |
49 | check_show default "$TIME" 'Wed Jun 15 16:13:20 2016 +0200' | |
50 | check_show raw "$TIME" '1466000000 +0200' | |
642833db | 51 | check_show unix "$TIME" '1466000000' |
36d67921 | 52 | check_show iso-local "$TIME" '2016-06-15 14:13:20 +0000' |
1a2a1e8e | 53 | check_show raw-local "$TIME" '1466000000 +0000' |
642833db | 54 | check_show unix-local "$TIME" '1466000000' |
36d67921 | 55 | |
c3fbf81a RS |
56 | check_show 'format:%z' "$TIME" '+0200' |
57 | check_show 'format-local:%z' "$TIME" '+0000' | |
58 | check_show 'format:%Z' "$TIME" '' | |
6eced3ec | 59 | check_show 'format-local:%Z' "$TIME" 'UTC' |
c3fbf81a RS |
60 | check_show 'format:%%z' "$TIME" '%z' |
61 | check_show 'format-local:%%z' "$TIME" '%z' | |
62 | ||
22280d7e JK |
63 | check_show 'format:%Y-%m-%d %H:%M:%S' "$TIME" '2016-06-15 16:13:20' |
64 | check_show 'format-local:%Y-%m-%d %H:%M:%S' "$TIME" '2016-06-15 09:13:20' '' EST5 | |
65 | ||
bab74837 JK |
66 | # arbitrary time absurdly far in the future |
67 | FUTURE="5758122296 -0400" | |
efac8ac8 JS |
68 | check_show iso "$FUTURE" "2152-06-19 18:24:56 -0400" TIME_IS_64BIT,TIME_T_IS_64BIT |
69 | check_show iso-local "$FUTURE" "2152-06-19 22:24:56 +0000" TIME_IS_64BIT,TIME_T_IS_64BIT | |
bab74837 | 70 | |
34dc6e73 JK |
71 | check_parse() { |
72 | echo "$1 -> $2" >expect | |
6b097788 | 73 | test_expect_${4:-success} "parse date ($1${3:+ TZ=$3})" " |
a801a7cf | 74 | TZ=${3:-$TZ} test-tool date parse '$1' >actual && |
34dc6e73 JK |
75 | test_cmp expect actual |
76 | " | |
77 | } | |
78 | ||
79 | check_parse 2008 bad | |
80 | check_parse 2008-02 bad | |
81 | check_parse 2008-02-14 bad | |
82 | check_parse '2008-02-14 20:30:45' '2008-02-14 20:30:45 +0000' | |
6b097788 | 83 | check_parse '2008-02-14 20:30:45 -0500' '2008-02-14 20:30:45 -0500' |
ee646eb4 HL |
84 | check_parse '2008-02-14 20:30:45 -0015' '2008-02-14 20:30:45 -0015' |
85 | check_parse '2008-02-14 20:30:45 -5' '2008-02-14 20:30:45 +0000' | |
86 | check_parse '2008-02-14 20:30:45 -5:' '2008-02-14 20:30:45 +0000' | |
87 | check_parse '2008-02-14 20:30:45 -05' '2008-02-14 20:30:45 -0500' | |
88 | check_parse '2008-02-14 20:30:45 -:30' '2008-02-14 20:30:45 +0000' | |
89 | check_parse '2008-02-14 20:30:45 -05:00' '2008-02-14 20:30:45 -0500' | |
0cc4da30 | 90 | check_parse '2008-02-14 20:30:45' '2008-02-14 20:30:45 -0500' EST5 |
34dc6e73 JK |
91 | |
92 | check_approxidate() { | |
93 | echo "$1 -> $2 +0000" >expect | |
94 | test_expect_${3:-success} "parse approxidate ($1)" " | |
a801a7cf | 95 | test-tool date approxidate '$1' >actual && |
34dc6e73 JK |
96 | test_cmp expect actual |
97 | " | |
98 | } | |
99 | ||
100 | check_approxidate now '2009-08-30 19:20:00' | |
101 | check_approxidate '5 seconds ago' '2009-08-30 19:19:55' | |
102 | check_approxidate 5.seconds.ago '2009-08-30 19:19:55' | |
103 | check_approxidate 10.minutes.ago '2009-08-30 19:10:00' | |
104 | check_approxidate yesterday '2009-08-29 19:20:00' | |
105 | check_approxidate 3.days.ago '2009-08-27 19:20:00' | |
106 | check_approxidate 3.weeks.ago '2009-08-09 19:20:00' | |
931e8e27 JK |
107 | check_approxidate 3.months.ago '2009-05-30 19:20:00' |
108 | check_approxidate 2.years.3.months.ago '2007-05-30 19:20:00' | |
34dc6e73 JK |
109 | |
110 | check_approxidate '6am yesterday' '2009-08-29 06:00:00' | |
111 | check_approxidate '6pm yesterday' '2009-08-29 18:00:00' | |
112 | check_approxidate '3:00' '2009-08-30 03:00:00' | |
113 | check_approxidate '15:00' '2009-08-30 15:00:00' | |
114 | check_approxidate 'noon today' '2009-08-30 12:00:00' | |
115 | check_approxidate 'noon yesterday' '2009-08-29 12:00:00' | |
c27cc94f | 116 | check_approxidate 'January 5th noon pm' '2009-01-05 12:00:00' |
aa097b88 | 117 | check_approxidate '10am noon' '2009-08-29 12:00:00' |
34dc6e73 JK |
118 | |
119 | check_approxidate 'last tuesday' '2009-08-25 19:20:00' | |
120 | check_approxidate 'July 5th' '2009-07-05 19:20:00' | |
121 | check_approxidate '06/05/2009' '2009-06-05 19:20:00' | |
122 | check_approxidate '06.05.2009' '2009-05-06 19:20:00' | |
123 | ||
124 | check_approxidate 'Jun 6, 5AM' '2009-06-06 05:00:00' | |
125 | check_approxidate '5AM Jun 6' '2009-06-06 05:00:00' | |
126 | check_approxidate '6AM, June 7, 2009' '2009-06-07 06:00:00' | |
127 | ||
d3723953 JK |
128 | check_approxidate '2008-12-01' '2008-12-01 19:20:00' |
129 | check_approxidate '2009-12-01' '2009-12-01 19:20:00' | |
130 | ||
110a6a16 SS |
131 | check_date_format_human() { |
132 | t=$(($GIT_TEST_DATE_NOW - $1)) | |
133 | echo "$t -> $2" >expect | |
134 | test_expect_success "human date $t" ' | |
135 | test-tool date human $t >actual && | |
136 | test_i18ncmp expect actual | |
137 | ' | |
138 | } | |
139 | ||
140 | check_date_format_human 18000 "5 hours ago" # 5 hours ago | |
141 | check_date_format_human 432000 "Tue Aug 25 19:20" # 5 days ago | |
142 | check_date_format_human 1728000 "Mon Aug 10 19:20" # 3 weeks ago | |
143 | check_date_format_human 13000000 "Thu Apr 2 08:13" # 5 months ago | |
144 | check_date_format_human 31449600 "Aug 31 2008" # 12 months ago | |
145 | check_date_format_human 37500000 "Jun 22 2008" # 1 year, 2 months ago | |
146 | check_date_format_human 55188000 "Dec 1 2007" # 1 year, 9 months ago | |
147 | check_date_format_human 630000000 "Sep 13 1989" # 20 years ago | |
148 | ||
34dc6e73 | 149 | test_done |