1 USING: accessors kernel math.order random threads tools.test ;
4 { f } [ 2004 12 32 0 0 0 instant <timestamp> valid-timestamp? ] unit-test
5 { f } [ 2004 2 30 0 0 0 instant <timestamp> valid-timestamp? ] unit-test
6 { f } [ 2003 2 29 0 0 0 instant <timestamp> valid-timestamp? ] unit-test
7 { f } [ 2004 -2 9 0 0 0 instant <timestamp> valid-timestamp? ] unit-test
8 { f } [ 2004 12 0 0 0 0 instant <timestamp> valid-timestamp? ] unit-test
9 { f } [ 2004 12 1 24 0 0 instant <timestamp> valid-timestamp? ] unit-test
10 { f } [ 2004 12 1 23 60 0 instant <timestamp> valid-timestamp? ] unit-test
11 { f } [ 2004 12 1 23 59 60 instant <timestamp> valid-timestamp? ] unit-test
12 { t } [ now valid-timestamp? ] unit-test
14 { f } [ 1900 leap-year? ] unit-test
15 { t } [ 1904 leap-year? ] unit-test
16 { t } [ 2000 leap-year? ] unit-test
17 { f } [ 2001 leap-year? ] unit-test
18 { f } [ 2006 leap-year? ] unit-test
20 { t } [ 2006 10 10 0 0 0 instant <timestamp> 1 seconds time+
21 2006 10 10 0 0 1 instant <timestamp> = ] unit-test
22 { t } [ 2006 10 10 0 0 0 instant <timestamp> 100 seconds time+
23 2006 10 10 0 1 40 instant <timestamp> = ] unit-test
24 { t } [ 2006 10 10 0 0 0 instant <timestamp> -100 seconds time+
25 2006 10 9 23 58 20 instant <timestamp> = ] unit-test
26 { t } [ 2006 10 10 0 0 0 instant <timestamp> 86400 seconds time+
27 2006 10 11 0 0 0 instant <timestamp> = ] unit-test
29 { t } [ 2006 10 10 0 0 0 instant <timestamp> 10 minutes time+
30 2006 10 10 0 10 0 instant <timestamp> = ] unit-test
31 { +eq+ } [ 2006 10 10 0 0 0 instant <timestamp> 10.5 minutes time+
32 2006 10 10 0 10 30 instant <timestamp> <=> ] unit-test
33 { t } [ 2006 10 10 0 0 0 instant <timestamp> 3/4 minutes time+
34 2006 10 10 0 0 45 instant <timestamp> = ] unit-test
35 { t } [ 2006 10 10 0 0 0 instant <timestamp> -3/4 minutes time+
36 2006 10 9 23 59 15 instant <timestamp> = ] unit-test
38 { t } [ 2006 10 10 0 0 0 instant <timestamp> 7200 minutes time+
39 2006 10 15 0 0 0 instant <timestamp> = ] unit-test
40 { t } [ 2006 10 10 0 0 0 instant <timestamp> -10 minutes time+
41 2006 10 9 23 50 0 instant <timestamp> = ] unit-test
42 { t } [ 2006 10 10 0 0 0 instant <timestamp> -100 minutes time+
43 2006 10 9 22 20 0 instant <timestamp> = ] unit-test
45 { t } [ 2006 1 1 0 0 0 instant <timestamp> 1 hours time+
46 2006 1 1 1 0 0 instant <timestamp> = ] unit-test
47 { t } [ 2006 1 1 0 0 0 instant <timestamp> 24 hours time+
48 2006 1 2 0 0 0 instant <timestamp> = ] unit-test
49 { t } [ 2006 1 1 0 0 0 instant <timestamp> -24 hours time+
50 2005 12 31 0 0 0 instant <timestamp> = ] unit-test
51 { t } [ 2006 1 1 0 0 0 instant <timestamp> 12 hours time+
52 2006 1 1 12 0 0 instant <timestamp> = ] unit-test
53 { t } [ 2006 1 1 0 0 0 instant <timestamp> 72 hours time+
54 2006 1 4 0 0 0 instant <timestamp> = ] unit-test
56 { t } [ 2006 1 1 0 0 0 instant <timestamp> 1 days time+
57 2006 1 2 0 0 0 instant <timestamp> = ] unit-test
58 { t } [ 2006 1 1 0 0 0 instant <timestamp> -1 days time+
59 2005 12 31 0 0 0 instant <timestamp> = ] unit-test
60 { t } [ 2006 1 1 0 0 0 instant <timestamp> 365 days time+
61 2007 1 1 0 0 0 instant <timestamp> = ] unit-test
62 { t } [ 2006 1 1 0 0 0 instant <timestamp> -365 days time+
63 2005 1 1 0 0 0 instant <timestamp> = ] unit-test
64 { t } [ 2004 1 1 0 0 0 instant <timestamp> 365 days time+
65 2004 12 31 0 0 0 instant <timestamp> = ] unit-test
66 { t } [ 2004 1 1 0 0 0 instant <timestamp> 366 days time+
67 2005 1 1 0 0 0 instant <timestamp> = ] unit-test
69 { t } [ 2006 1 1 0 0 0 instant <timestamp> 11 months time+
70 2006 12 1 0 0 0 instant <timestamp> = ] unit-test
71 { t } [ 2006 1 1 0 0 0 instant <timestamp> 12 months time+
72 2007 1 1 0 0 0 instant <timestamp> = ] unit-test
73 { t } [ 2006 1 1 0 0 0 instant <timestamp> 24 months time+
74 2008 1 1 0 0 0 instant <timestamp> = ] unit-test
75 { t } [ 2006 1 1 0 0 0 instant <timestamp> 13 months time+
76 2007 2 1 0 0 0 instant <timestamp> = ] unit-test
77 { t } [ 2006 1 1 0 0 0 instant <timestamp> 1 months time+
78 2006 2 1 0 0 0 instant <timestamp> = ] unit-test
79 { t } [ 2006 1 1 0 0 0 instant <timestamp> 0 months time+
80 2006 1 1 0 0 0 instant <timestamp> = ] unit-test
81 { t } [ 2006 1 1 0 0 0 instant <timestamp> -1 months time+
82 2005 12 1 0 0 0 instant <timestamp> = ] unit-test
83 { t } [ 2006 1 1 0 0 0 instant <timestamp> -2 months time+
84 2005 11 1 0 0 0 instant <timestamp> = ] unit-test
85 { t } [ 2006 1 1 0 0 0 instant <timestamp> -13 months time+
86 2004 12 1 0 0 0 instant <timestamp> = ] unit-test
87 { t } [ 2006 1 1 0 0 0 instant <timestamp> -24 months time+
88 2004 1 1 0 0 0 instant <timestamp> = ] unit-test
89 { t } [ 2004 2 29 0 0 0 instant <timestamp> 12 months time+
90 2005 3 1 0 0 0 instant <timestamp> = ] unit-test
91 { t } [ 2004 2 29 0 0 0 instant <timestamp> -12 months time+
92 2003 3 1 0 0 0 instant <timestamp> = ] unit-test
94 { t } [ 2006 1 1 0 0 0 instant <timestamp> 0 years time+
95 2006 1 1 0 0 0 instant <timestamp> = ] unit-test
96 { t } [ 2006 1 1 0 0 0 instant <timestamp> 1 years time+
97 2007 1 1 0 0 0 instant <timestamp> = ] unit-test
98 { t } [ 2006 1 1 0 0 0 instant <timestamp> -1 years time+
99 2005 1 1 0 0 0 instant <timestamp> = ] unit-test
100 { t } [ 2006 1 1 0 0 0 instant <timestamp> -100 years time+
101 1906 1 1 0 0 0 instant <timestamp> = ] unit-test
102 ! [ t ] [ 2004 2 29 0 0 0 instant <timestamp> -1 years time+
103 ! 2003 2 28 0 0 0 instant <timestamp> = ] unit-test
105 { 5 } [ 2006 7 14 0 0 0 instant <timestamp> day-of-week ] unit-test
107 { t } [ 2006 7 14 [ julian-day-number julian-day-number>date 0 0 0 instant <timestamp> ] 3keep 0 0 0 instant <timestamp> = ] unit-test
109 { 1 } [ 2006 1 1 0 0 0 instant <timestamp> day-of-year ] unit-test
110 { 60 } [ 2004 2 29 0 0 0 instant <timestamp> day-of-year ] unit-test
111 { 61 } [ 2004 3 1 0 0 0 instant <timestamp> day-of-year ] unit-test
112 { 366 } [ 2004 12 31 0 0 0 instant <timestamp> day-of-year ] unit-test
113 { 365 } [ 2003 12 31 0 0 0 instant <timestamp> day-of-year ] unit-test
114 { 60 } [ 2003 3 1 0 0 0 instant <timestamp> day-of-year ] unit-test
116 { t } [ 2004 12 31 0 0 0 instant <timestamp> dup = ] unit-test
117 { t } [ 2004 1 1 0 0 0 instant <timestamp> 10 seconds 5 years time+ time+
118 2009 1 1 0 0 10 instant <timestamp> = ] unit-test
119 { t } [ 2004 1 1 0 0 0 instant <timestamp> -10 seconds -5 years time+ time+
120 1998 12 31 23 59 50 instant <timestamp> = ] unit-test
122 { t } [ 2004 1 1 23 0 0 12 hours <timestamp> >gmt
123 2004 1 1 11 0 0 instant <timestamp> = ] unit-test
124 { t } [ 2004 1 1 5 0 0 -11 hours <timestamp> >gmt
125 2004 1 1 16 0 0 instant <timestamp> = ] unit-test
126 { t } [ 2004 1 1 23 0 0 9+1/2 hours <timestamp> >gmt
127 2004 1 1 13 30 0 instant <timestamp> = ] unit-test
129 { +eq+ } [ 2004 1 1 13 30 0 instant <timestamp>
130 2004 1 1 12 30 0 -1 hours <timestamp> <=> ] unit-test
132 { +gt+ } [ 2004 1 1 13 30 0 instant <timestamp>
133 2004 1 1 12 30 0 instant <timestamp> <=> ] unit-test
135 { +lt+ } [ 2004 1 1 12 30 0 instant <timestamp>
136 2004 1 1 13 30 0 instant <timestamp> <=> ] unit-test
138 { +gt+ } [ 2005 1 1 12 30 0 instant <timestamp>
139 2004 1 1 13 30 0 instant <timestamp> <=> ] unit-test
141 { t } [ 0 micros>timestamp unix-1970 = ] unit-test
142 { t } [ 123456789000000 [ micros>timestamp timestamp>micros ] keep = ] unit-test
143 { t } [ 123456789123456000 [ micros>timestamp timestamp>micros ] keep = ] unit-test
145 : checktime+ ( duration -- ? ) now dup clone [ rot time+ drop ] keep = ;
147 { t } [ 5 seconds checktime+ ] unit-test
149 { t } [ 5 minutes checktime+ ] unit-test
151 { t } [ 5 hours checktime+ ] unit-test
153 { t } [ 5 days checktime+ ] unit-test
155 { t } [ 5 weeks checktime+ ] unit-test
157 { t } [ 5 months checktime+ ] unit-test
159 { t } [ 5 years checktime+ ] unit-test
161 { t } [ now 50 milliseconds sleep now before? ] unit-test
162 { t } [ now 50 milliseconds sleep now swap after? ] unit-test
163 { t } [ now 50 milliseconds sleep now 50 milliseconds sleep now swapd between? ] unit-test
165 { 4 12 } [ 2009 easter [ month>> ] [ day>> ] bi ] unit-test
166 { 4 2 } [ 1961 easter [ month>> ] [ day>> ] bi ] unit-test
168 { f } [ now dup midnight eq? ] unit-test
169 { f } [ now dup easter eq? ] unit-test
170 { f } [ now dup beginning-of-year eq? ] unit-test
172 { t } [ 1325376000 unix-time>timestamp 2012 <year-gmt> = ] unit-test
173 { t } [ 1356998399 unix-time>timestamp 2013 <year-gmt> 1 seconds time- = ] unit-test
175 { t } [ 1500000000 random [ unix-time>timestamp timestamp>unix-time ] keep = ] unit-test
178 2009 1 29 <date> 1 months time+
183 2008 1 29 <date> 1 months time+
188 [ gmt gmt-offset>> duration>seconds ] unit-test