ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/jsr166/jsr166/src/test/tck/TimeUnitTest.java
(Generate patch)

Comparing jsr166/src/test/tck/TimeUnitTest.java (file contents):
Revision 1.9 by dl, Thu Dec 30 13:04:50 2004 UTC vs.
Revision 1.27 by jsr166, Sat Jan 30 22:24:32 2016 UTC

# Line 1 | Line 1
1   /*
2   * Written by Doug Lea with assistance from members of JCP JSR-166
3   * Expert Group and released to the public domain, as explained at
4 < * http://creativecommons.org/licenses/publicdomain
5 < * Other contributors include Andrew Wright, Jeffrey Hayes,
6 < * Pat Fisher, Mike Judd.
4 > * http://creativecommons.org/publicdomain/zero/1.0/
5 > * Other contributors include Andrew Wright, Jeffrey Hayes,
6 > * Pat Fisher, Mike Judd.
7   */
8  
9 + import static java.util.concurrent.TimeUnit.DAYS;
10 + import static java.util.concurrent.TimeUnit.HOURS;
11 + import static java.util.concurrent.TimeUnit.MICROSECONDS;
12 + import static java.util.concurrent.TimeUnit.MILLISECONDS;
13 + import static java.util.concurrent.TimeUnit.MINUTES;
14 + import static java.util.concurrent.TimeUnit.NANOSECONDS;
15 + import static java.util.concurrent.TimeUnit.SECONDS;
16 +
17 + import java.time.temporal.ChronoUnit;
18 + import java.util.concurrent.CountDownLatch;
19 + import java.util.concurrent.TimeUnit;
20  
21 < import junit.framework.*;
22 < import java.util.concurrent.*;
12 < import java.io.*;
21 > import junit.framework.Test;
22 > import junit.framework.TestSuite;
23  
24   public class TimeUnitTest extends JSR166TestCase {
25      public static void main(String[] args) {
26 <        junit.textui.TestRunner.run(suite());  
26 >        main(suite(), args);
27      }
28 <    
28 >
29      public static Test suite() {
30 <        return new TestSuite(TimeUnitTest.class);
30 >        return new TestSuite(TimeUnitTest.class);
31      }
32  
33      // (loops to 88888 check increments at all time divisions.)
# Line 27 | Line 37 | public class TimeUnitTest extends JSR166
37       */
38      public void testConvert() {
39          for (long t = 0; t < 88888; ++t) {
40 <            assertEquals(t*60*60*24,
41 <                         TimeUnit.SECONDS.convert(t,
42 <                                                  TimeUnit.DAYS));
43 <            assertEquals(t*60*60,
44 <                         TimeUnit.SECONDS.convert(t,
45 <                                                  TimeUnit.HOURS));
46 <            assertEquals(t*60,
47 <                         TimeUnit.SECONDS.convert(t,
48 <                                                  TimeUnit.MINUTES));
49 <            assertEquals(t,
50 <                         TimeUnit.SECONDS.convert(t,
51 <                                                  TimeUnit.SECONDS));
52 <            assertEquals(t,
53 <                         TimeUnit.SECONDS.convert(1000L*t,
54 <                                                  TimeUnit.MILLISECONDS));
55 <            assertEquals(t,
56 <                         TimeUnit.SECONDS.convert(1000000L*t,
57 <                                                  TimeUnit.MICROSECONDS));
58 <            assertEquals(t,
59 <                         TimeUnit.SECONDS.convert(1000000000L*t,
60 <                                                  TimeUnit.NANOSECONDS));
61 <
62 <
63 <            assertEquals(1000L*t*60*60*24,
64 <                         TimeUnit.MILLISECONDS.convert(t,
65 <                                                  TimeUnit.DAYS));
66 <            assertEquals(1000L*t*60*60,
67 <                         TimeUnit.MILLISECONDS.convert(t,
68 <                                                  TimeUnit.HOURS));
69 <            assertEquals(1000L*t*60,
70 <                         TimeUnit.MILLISECONDS.convert(t,
71 <                                                  TimeUnit.MINUTES));
72 <            assertEquals(1000L*t,
73 <                         TimeUnit.MILLISECONDS.convert(t,
74 <                                                  TimeUnit.SECONDS));
75 <            assertEquals(t,
76 <                         TimeUnit.MILLISECONDS.convert(t,
77 <                                                  TimeUnit.MILLISECONDS));
78 <            assertEquals(t,
79 <                         TimeUnit.MILLISECONDS.convert(1000L*t,
80 <                                                  TimeUnit.MICROSECONDS));
81 <            assertEquals(t,
82 <                         TimeUnit.MILLISECONDS.convert(1000000L*t,
83 <                                                  TimeUnit.NANOSECONDS));
84 <
85 <            assertEquals(1000000L*t*60*60*24,
86 <                         TimeUnit.MICROSECONDS.convert(t,
87 <                                                  TimeUnit.DAYS));
88 <            assertEquals(1000000L*t*60*60,
89 <                         TimeUnit.MICROSECONDS.convert(t,
90 <                                                  TimeUnit.HOURS));
91 <            assertEquals(1000000L*t*60,
92 <                         TimeUnit.MICROSECONDS.convert(t,
93 <                                                  TimeUnit.MINUTES));
94 <            assertEquals(1000000L*t,
95 <                         TimeUnit.MICROSECONDS.convert(t,
96 <                                                  TimeUnit.SECONDS));
97 <            assertEquals(1000L*t,
98 <                         TimeUnit.MICROSECONDS.convert(t,
89 <                                                  TimeUnit.MILLISECONDS));
90 <            assertEquals(t,
91 <                         TimeUnit.MICROSECONDS.convert(t,
92 <                                                  TimeUnit.MICROSECONDS));
93 <            assertEquals(t,
94 <                         TimeUnit.MICROSECONDS.convert(1000L*t,
95 <                                                  TimeUnit.NANOSECONDS));
96 <
97 <            assertEquals(1000000000L*t*60*60*24,
98 <                         TimeUnit.NANOSECONDS.convert(t,
99 <                                                  TimeUnit.DAYS));
100 <            assertEquals(1000000000L*t*60*60,
101 <                         TimeUnit.NANOSECONDS.convert(t,
102 <                                                  TimeUnit.HOURS));
103 <            assertEquals(1000000000L*t*60,
104 <                         TimeUnit.NANOSECONDS.convert(t,
105 <                                                  TimeUnit.MINUTES));
106 <            assertEquals(1000000000L*t,
107 <                         TimeUnit.NANOSECONDS.convert(t,
108 <                                                  TimeUnit.SECONDS));
109 <            assertEquals(1000000L*t,
110 <                         TimeUnit.NANOSECONDS.convert(t,
111 <                                                  TimeUnit.MILLISECONDS));
112 <            assertEquals(1000L*t,
113 <                         TimeUnit.NANOSECONDS.convert(t,
114 <                                                  TimeUnit.MICROSECONDS));
115 <            assertEquals(t,
116 <                         TimeUnit.NANOSECONDS.convert(t,
117 <                                                  TimeUnit.NANOSECONDS));
40 >            assertEquals(t*60*60*24,
41 >                         SECONDS.convert(t, DAYS));
42 >            assertEquals(t*60*60,
43 >                         SECONDS.convert(t, HOURS));
44 >            assertEquals(t*60,
45 >                         SECONDS.convert(t, MINUTES));
46 >            assertEquals(t,
47 >                         SECONDS.convert(t, SECONDS));
48 >            assertEquals(t,
49 >                         SECONDS.convert(1000L*t, MILLISECONDS));
50 >            assertEquals(t,
51 >                         SECONDS.convert(1000000L*t, MICROSECONDS));
52 >            assertEquals(t,
53 >                         SECONDS.convert(1000000000L*t, NANOSECONDS));
54 >
55 >            assertEquals(1000L*t*60*60*24,
56 >                         MILLISECONDS.convert(t, DAYS));
57 >            assertEquals(1000L*t*60*60,
58 >                         MILLISECONDS.convert(t, HOURS));
59 >            assertEquals(1000L*t*60,
60 >                         MILLISECONDS.convert(t, MINUTES));
61 >            assertEquals(1000L*t,
62 >                         MILLISECONDS.convert(t, SECONDS));
63 >            assertEquals(t,
64 >                         MILLISECONDS.convert(t, MILLISECONDS));
65 >            assertEquals(t,
66 >                         MILLISECONDS.convert(1000L*t, MICROSECONDS));
67 >            assertEquals(t,
68 >                         MILLISECONDS.convert(1000000L*t, NANOSECONDS));
69 >
70 >            assertEquals(1000000L*t*60*60*24,
71 >                         MICROSECONDS.convert(t, DAYS));
72 >            assertEquals(1000000L*t*60*60,
73 >                         MICROSECONDS.convert(t, HOURS));
74 >            assertEquals(1000000L*t*60,
75 >                         MICROSECONDS.convert(t, MINUTES));
76 >            assertEquals(1000000L*t,
77 >                         MICROSECONDS.convert(t, SECONDS));
78 >            assertEquals(1000L*t,
79 >                         MICROSECONDS.convert(t, MILLISECONDS));
80 >            assertEquals(t,
81 >                         MICROSECONDS.convert(t, MICROSECONDS));
82 >            assertEquals(t,
83 >                         MICROSECONDS.convert(1000L*t, NANOSECONDS));
84 >
85 >            assertEquals(1000000000L*t*60*60*24,
86 >                         NANOSECONDS.convert(t, DAYS));
87 >            assertEquals(1000000000L*t*60*60,
88 >                         NANOSECONDS.convert(t, HOURS));
89 >            assertEquals(1000000000L*t*60,
90 >                         NANOSECONDS.convert(t, MINUTES));
91 >            assertEquals(1000000000L*t,
92 >                         NANOSECONDS.convert(t, SECONDS));
93 >            assertEquals(1000000L*t,
94 >                         NANOSECONDS.convert(t, MILLISECONDS));
95 >            assertEquals(1000L*t,
96 >                         NANOSECONDS.convert(t, MICROSECONDS));
97 >            assertEquals(t,
98 >                         NANOSECONDS.convert(t, NANOSECONDS));
99          }
100      }
101  
# Line 124 | Line 105 | public class TimeUnitTest extends JSR166
105       */
106      public void testToNanos() {
107          for (long t = 0; t < 88888; ++t) {
108 <            assertEquals(t*1000000000L*60*60*24,
109 <                         TimeUnit.DAYS.toNanos(t));
110 <            assertEquals(t*1000000000L*60*60,
111 <                         TimeUnit.HOURS.toNanos(t));
112 <            assertEquals(t*1000000000L*60,
113 <                         TimeUnit.MINUTES.toNanos(t));
114 <            assertEquals(1000000000L*t,
115 <                         TimeUnit.SECONDS.toNanos(t));
116 <            assertEquals(1000000L*t,
117 <                         TimeUnit.MILLISECONDS.toNanos(t));
118 <            assertEquals(1000L*t,
119 <                         TimeUnit.MICROSECONDS.toNanos(t));
120 <            assertEquals(t,
121 <                         TimeUnit.NANOSECONDS.toNanos(t));
108 >            assertEquals(t*1000000000L*60*60*24,
109 >                         DAYS.toNanos(t));
110 >            assertEquals(t*1000000000L*60*60,
111 >                         HOURS.toNanos(t));
112 >            assertEquals(t*1000000000L*60,
113 >                         MINUTES.toNanos(t));
114 >            assertEquals(1000000000L*t,
115 >                         SECONDS.toNanos(t));
116 >            assertEquals(1000000L*t,
117 >                         MILLISECONDS.toNanos(t));
118 >            assertEquals(1000L*t,
119 >                         MICROSECONDS.toNanos(t));
120 >            assertEquals(t,
121 >                         NANOSECONDS.toNanos(t));
122          }
123      }
124  
# Line 147 | Line 128 | public class TimeUnitTest extends JSR166
128       */
129      public void testToMicros() {
130          for (long t = 0; t < 88888; ++t) {
131 <            assertEquals(t*1000000L*60*60*24,
132 <                         TimeUnit.DAYS.toMicros(t));
133 <            assertEquals(t*1000000L*60*60,
134 <                         TimeUnit.HOURS.toMicros(t));
135 <            assertEquals(t*1000000L*60,
136 <                         TimeUnit.MINUTES.toMicros(t));
137 <            assertEquals(1000000L*t,
138 <                         TimeUnit.SECONDS.toMicros(t));
139 <            assertEquals(1000L*t,
140 <                         TimeUnit.MILLISECONDS.toMicros(t));
141 <            assertEquals(t,
142 <                         TimeUnit.MICROSECONDS.toMicros(t));
143 <            assertEquals(t,
144 <                         TimeUnit.NANOSECONDS.toMicros(t*1000L));
131 >            assertEquals(t*1000000L*60*60*24,
132 >                         DAYS.toMicros(t));
133 >            assertEquals(t*1000000L*60*60,
134 >                         HOURS.toMicros(t));
135 >            assertEquals(t*1000000L*60,
136 >                         MINUTES.toMicros(t));
137 >            assertEquals(1000000L*t,
138 >                         SECONDS.toMicros(t));
139 >            assertEquals(1000L*t,
140 >                         MILLISECONDS.toMicros(t));
141 >            assertEquals(t,
142 >                         MICROSECONDS.toMicros(t));
143 >            assertEquals(t,
144 >                         NANOSECONDS.toMicros(t*1000L));
145          }
146      }
147  
# Line 170 | Line 151 | public class TimeUnitTest extends JSR166
151       */
152      public void testToMillis() {
153          for (long t = 0; t < 88888; ++t) {
154 <            assertEquals(t*1000L*60*60*24,
155 <                         TimeUnit.DAYS.toMillis(t));
156 <            assertEquals(t*1000L*60*60,
157 <                         TimeUnit.HOURS.toMillis(t));
158 <            assertEquals(t*1000L*60,
159 <                         TimeUnit.MINUTES.toMillis(t));
160 <            assertEquals(1000L*t,
161 <                         TimeUnit.SECONDS.toMillis(t));
162 <            assertEquals(t,
163 <                         TimeUnit.MILLISECONDS.toMillis(t));
164 <            assertEquals(t,
165 <                         TimeUnit.MICROSECONDS.toMillis(t*1000L));
166 <            assertEquals(t,
167 <                         TimeUnit.NANOSECONDS.toMillis(t*1000000L));
154 >            assertEquals(t*1000L*60*60*24,
155 >                         DAYS.toMillis(t));
156 >            assertEquals(t*1000L*60*60,
157 >                         HOURS.toMillis(t));
158 >            assertEquals(t*1000L*60,
159 >                         MINUTES.toMillis(t));
160 >            assertEquals(1000L*t,
161 >                         SECONDS.toMillis(t));
162 >            assertEquals(t,
163 >                         MILLISECONDS.toMillis(t));
164 >            assertEquals(t,
165 >                         MICROSECONDS.toMillis(t*1000L));
166 >            assertEquals(t,
167 >                         NANOSECONDS.toMillis(t*1000000L));
168          }
169      }
170  
# Line 193 | Line 174 | public class TimeUnitTest extends JSR166
174       */
175      public void testToSeconds() {
176          for (long t = 0; t < 88888; ++t) {
177 <            assertEquals(t*60*60*24,
178 <                         TimeUnit.DAYS.toSeconds(t));
179 <            assertEquals(t*60*60,
180 <                         TimeUnit.HOURS.toSeconds(t));
181 <            assertEquals(t*60,
182 <                         TimeUnit.MINUTES.toSeconds(t));
183 <            assertEquals(t,
184 <                         TimeUnit.SECONDS.toSeconds(t));
185 <            assertEquals(t,
186 <                         TimeUnit.MILLISECONDS.toSeconds(t*1000L));
187 <            assertEquals(t,
188 <                         TimeUnit.MICROSECONDS.toSeconds(t*1000000L));
189 <            assertEquals(t,
190 <                         TimeUnit.NANOSECONDS.toSeconds(t*1000000000L));
177 >            assertEquals(t*60*60*24,
178 >                         DAYS.toSeconds(t));
179 >            assertEquals(t*60*60,
180 >                         HOURS.toSeconds(t));
181 >            assertEquals(t*60,
182 >                         MINUTES.toSeconds(t));
183 >            assertEquals(t,
184 >                         SECONDS.toSeconds(t));
185 >            assertEquals(t,
186 >                         MILLISECONDS.toSeconds(t*1000L));
187 >            assertEquals(t,
188 >                         MICROSECONDS.toSeconds(t*1000000L));
189 >            assertEquals(t,
190 >                         NANOSECONDS.toSeconds(t*1000000000L));
191          }
192      }
193  
# Line 216 | Line 197 | public class TimeUnitTest extends JSR166
197       */
198      public void testToMinutes() {
199          for (long t = 0; t < 88888; ++t) {
200 <            assertEquals(t*60*24,
201 <                         TimeUnit.DAYS.toMinutes(t));
202 <            assertEquals(t*60,
203 <                         TimeUnit.HOURS.toMinutes(t));
204 <            assertEquals(t,
205 <                         TimeUnit.MINUTES.toMinutes(t));
206 <            assertEquals(t,
207 <                         TimeUnit.SECONDS.toMinutes(t*60));
208 <            assertEquals(t,
209 <                         TimeUnit.MILLISECONDS.toMinutes(t*1000L*60));
210 <            assertEquals(t,
211 <                         TimeUnit.MICROSECONDS.toMinutes(t*1000000L*60));
212 <            assertEquals(t,
213 <                         TimeUnit.NANOSECONDS.toMinutes(t*1000000000L*60));
200 >            assertEquals(t*60*24,
201 >                         DAYS.toMinutes(t));
202 >            assertEquals(t*60,
203 >                         HOURS.toMinutes(t));
204 >            assertEquals(t,
205 >                         MINUTES.toMinutes(t));
206 >            assertEquals(t,
207 >                         SECONDS.toMinutes(t*60));
208 >            assertEquals(t,
209 >                         MILLISECONDS.toMinutes(t*1000L*60));
210 >            assertEquals(t,
211 >                         MICROSECONDS.toMinutes(t*1000000L*60));
212 >            assertEquals(t,
213 >                         NANOSECONDS.toMinutes(t*1000000000L*60));
214          }
215      }
216  
# Line 239 | Line 220 | public class TimeUnitTest extends JSR166
220       */
221      public void testToHours() {
222          for (long t = 0; t < 88888; ++t) {
223 <            assertEquals(t*24,
224 <                         TimeUnit.DAYS.toHours(t));
225 <            assertEquals(t,
226 <                         TimeUnit.HOURS.toHours(t));
227 <            assertEquals(t,
228 <                         TimeUnit.MINUTES.toHours(t*60));
229 <            assertEquals(t,
230 <                         TimeUnit.SECONDS.toHours(t*60*60));
231 <            assertEquals(t,
232 <                         TimeUnit.MILLISECONDS.toHours(t*1000L*60*60));
233 <            assertEquals(t,
234 <                         TimeUnit.MICROSECONDS.toHours(t*1000000L*60*60));
235 <            assertEquals(t,
236 <                         TimeUnit.NANOSECONDS.toHours(t*1000000000L*60*60));
223 >            assertEquals(t*24,
224 >                         DAYS.toHours(t));
225 >            assertEquals(t,
226 >                         HOURS.toHours(t));
227 >            assertEquals(t,
228 >                         MINUTES.toHours(t*60));
229 >            assertEquals(t,
230 >                         SECONDS.toHours(t*60*60));
231 >            assertEquals(t,
232 >                         MILLISECONDS.toHours(t*1000L*60*60));
233 >            assertEquals(t,
234 >                         MICROSECONDS.toHours(t*1000000L*60*60));
235 >            assertEquals(t,
236 >                         NANOSECONDS.toHours(t*1000000000L*60*60));
237          }
238      }
239  
# Line 262 | Line 243 | public class TimeUnitTest extends JSR166
243       */
244      public void testToDays() {
245          for (long t = 0; t < 88888; ++t) {
246 <            assertEquals(t,
247 <                         TimeUnit.DAYS.toDays(t));
248 <            assertEquals(t,
249 <                         TimeUnit.HOURS.toDays(t*24));
250 <            assertEquals(t,
251 <                         TimeUnit.MINUTES.toDays(t*60*24));
252 <            assertEquals(t,
253 <                         TimeUnit.SECONDS.toDays(t*60*60*24));
254 <            assertEquals(t,
255 <                         TimeUnit.MILLISECONDS.toDays(t*1000L*60*60*24));
256 <            assertEquals(t,
257 <                         TimeUnit.MICROSECONDS.toDays(t*1000000L*60*60*24));
258 <            assertEquals(t,
259 <                         TimeUnit.NANOSECONDS.toDays(t*1000000000L*60*60*24));
246 >            assertEquals(t,
247 >                         DAYS.toDays(t));
248 >            assertEquals(t,
249 >                         HOURS.toDays(t*24));
250 >            assertEquals(t,
251 >                         MINUTES.toDays(t*60*24));
252 >            assertEquals(t,
253 >                         SECONDS.toDays(t*60*60*24));
254 >            assertEquals(t,
255 >                         MILLISECONDS.toDays(t*1000L*60*60*24));
256 >            assertEquals(t,
257 >                         MICROSECONDS.toDays(t*1000000L*60*60*24));
258 >            assertEquals(t,
259 >                         NANOSECONDS.toDays(t*1000000000L*60*60*24));
260          }
261      }
262  
282
263      /**
264 <     * convert saturates positive too-large values to Long.MAX_VALUE
264 >     * convert saturates positive too-large values to Long.MAX_VALUE
265       * and negative to LONG.MIN_VALUE
266       */
267      public void testConvertSaturate() {
268          assertEquals(Long.MAX_VALUE,
269 <                     TimeUnit.NANOSECONDS.convert(Long.MAX_VALUE / 2,
290 <                                                  TimeUnit.SECONDS));
269 >                     NANOSECONDS.convert(Long.MAX_VALUE / 2, SECONDS));
270          assertEquals(Long.MIN_VALUE,
271 <                     TimeUnit.NANOSECONDS.convert(-Long.MAX_VALUE / 4,
293 <                                                  TimeUnit.SECONDS));
271 >                     NANOSECONDS.convert(-Long.MAX_VALUE / 4, SECONDS));
272          assertEquals(Long.MAX_VALUE,
273 <                     TimeUnit.NANOSECONDS.convert(Long.MAX_VALUE / 2,
296 <                                                  TimeUnit.MINUTES));
273 >                     NANOSECONDS.convert(Long.MAX_VALUE / 2, MINUTES));
274          assertEquals(Long.MIN_VALUE,
275 <                     TimeUnit.NANOSECONDS.convert(-Long.MAX_VALUE / 4,
299 <                                                  TimeUnit.MINUTES));
275 >                     NANOSECONDS.convert(-Long.MAX_VALUE / 4, MINUTES));
276          assertEquals(Long.MAX_VALUE,
277 <                     TimeUnit.NANOSECONDS.convert(Long.MAX_VALUE / 2,
302 <                                                  TimeUnit.HOURS));
277 >                     NANOSECONDS.convert(Long.MAX_VALUE / 2, HOURS));
278          assertEquals(Long.MIN_VALUE,
279 <                     TimeUnit.NANOSECONDS.convert(-Long.MAX_VALUE / 4,
305 <                                                  TimeUnit.HOURS));
279 >                     NANOSECONDS.convert(-Long.MAX_VALUE / 4, HOURS));
280          assertEquals(Long.MAX_VALUE,
281 <                     TimeUnit.NANOSECONDS.convert(Long.MAX_VALUE / 2,
308 <                                                  TimeUnit.DAYS));
281 >                     NANOSECONDS.convert(Long.MAX_VALUE / 2, DAYS));
282          assertEquals(Long.MIN_VALUE,
283 <                     TimeUnit.NANOSECONDS.convert(-Long.MAX_VALUE / 4,
311 <                                                  TimeUnit.DAYS));
312 <
283 >                     NANOSECONDS.convert(-Long.MAX_VALUE / 4, DAYS));
284      }
285  
286      /**
287 <     * toNanos saturates positive too-large values to Long.MAX_VALUE
287 >     * toNanos saturates positive too-large values to Long.MAX_VALUE
288       * and negative to LONG.MIN_VALUE
289       */
290      public void testToNanosSaturate() {
291 <            assertEquals(Long.MAX_VALUE,
292 <                         TimeUnit.MILLISECONDS.toNanos(Long.MAX_VALUE / 2));
293 <            assertEquals(Long.MIN_VALUE,
294 <                         TimeUnit.MILLISECONDS.toNanos(-Long.MAX_VALUE / 3));
291 >        assertEquals(Long.MAX_VALUE,
292 >                     MILLISECONDS.toNanos(Long.MAX_VALUE / 2));
293 >        assertEquals(Long.MIN_VALUE,
294 >                     MILLISECONDS.toNanos(-Long.MAX_VALUE / 3));
295      }
296  
326
297      /**
298 <     * toString returns string containing common name of unit
298 >     * toString returns name of unit
299       */
300      public void testToString() {
301 <        String s = TimeUnit.SECONDS.toString();
332 <        assertTrue(s.indexOf("ECOND") >= 0);
301 >        assertEquals("SECONDS", SECONDS.toString());
302      }
303  
335    
304      /**
305 <     *  Timed wait without holding lock throws
338 <     *  IllegalMonitorStateException
305 >     * name returns name of unit
306       */
307 <    public void testTimedWait_IllegalMonitorException() {
308 <        //created a new thread with anonymous runnable
342 <
343 <        Thread t = new Thread(new Runnable() {
344 <                public void run() {
345 <                    Object o = new Object();
346 <                    TimeUnit tu = TimeUnit.MILLISECONDS;
347 <                    try {
348 <                        tu.timedWait(o,LONG_DELAY_MS);
349 <                        threadShouldThrow();
350 <                    }
351 <                    catch (InterruptedException ie) {
352 <                        threadUnexpectedException();
353 <                    }
354 <                    catch(IllegalMonitorStateException success) {
355 <                    }
356 <                    
357 <                }
358 <            });
359 <        t.start();
360 <        try {
361 <            Thread.sleep(SHORT_DELAY_MS);
362 <            t.interrupt();
363 <            t.join();
364 <        } catch(Exception e) {
365 <            unexpectedException();
366 <        }
307 >    public void testName() {
308 >        assertEquals("SECONDS", SECONDS.name());
309      }
310 <    
369 <    /**
370 <     * timedWait throws InterruptedException when interrupted
371 <     */
372 <    public void testTimedWait() {
373 <        Thread t = new Thread(new Runnable() {
374 <                public void run() {
375 <                    Object o = new Object();
376 <                    
377 <                    TimeUnit tu = TimeUnit.MILLISECONDS;
378 <                    try {
379 <                        synchronized(o) {
380 <                            tu.timedWait(o,MEDIUM_DELAY_MS);
381 <                        }
382 <                        threadShouldThrow();
383 <                    }
384 <                    catch(InterruptedException success) {}
385 <                    catch(IllegalMonitorStateException failure) {
386 <                        threadUnexpectedException();
387 <                    }
388 <                }
389 <            });
390 <        t.start();
391 <        try {
392 <            Thread.sleep(SHORT_DELAY_MS);
393 <            t.interrupt();
394 <            t.join();
395 <        } catch(Exception e) {
396 <            unexpectedException();
397 <        }
398 <    }
399 <    
400 <    
310 >
311      /**
312 <     * timedJoin throws InterruptedException when interrupted
312 >     * Timed wait without holding lock throws
313 >     * IllegalMonitorStateException
314       */
315 <    public void testTimedJoin() {
316 <        Thread t = new Thread(new Runnable() {
317 <                public void run() {
318 <                    TimeUnit tu = TimeUnit.MILLISECONDS;        
319 <                    try {
320 <                        Thread s = new Thread(new Runnable() {
321 <                                public void run() {
322 <                                    try {
323 <                                        Thread.sleep(MEDIUM_DELAY_MS);
324 <                                    } catch(InterruptedException success){}
325 <                                }
326 <                            });
327 <                        s.start();
417 <                        tu.timedJoin(s,MEDIUM_DELAY_MS);
418 <                        threadShouldThrow();
419 <                    }
420 <                    catch(Exception e) {}
421 <                }
422 <            });
423 <        t.start();
424 <        try {
425 <            Thread.sleep(SHORT_DELAY_MS);
426 <            t.interrupt();
427 <            t.join();
428 <        } catch(Exception e) {
429 <            unexpectedException();
430 <        }
315 >    public void testTimedWait_IllegalMonitorException() {
316 >        Thread t = newStartedThread(new CheckedRunnable() {
317 >            public void realRun() throws InterruptedException {
318 >                Object o = new Object();
319 >                TimeUnit tu = MILLISECONDS;
320 >
321 >                try {
322 >                    tu.timedWait(o, LONG_DELAY_MS);
323 >                    threadShouldThrow();
324 >                } catch (IllegalMonitorStateException success) {}
325 >            }});
326 >
327 >        awaitTermination(t);
328      }
329 <    
329 >
330      /**
331 <     *  timedSleep throws InterruptedException when interrupted
331 >     * timedWait throws InterruptedException when interrupted
332       */
333 <    public void testTimedSleep() {
334 <        //created a new thread with anonymous runnable
335 <
336 <        Thread t = new Thread(new Runnable() {
337 <                public void run() {
338 <                    TimeUnit tu = TimeUnit.MILLISECONDS;
339 <                    try {
340 <                        tu.sleep(MEDIUM_DELAY_MS);
341 <                        threadShouldThrow();
342 <                    }
343 <                    catch(InterruptedException success) {}
344 <                }
345 <            });
346 <        t.start();
347 <        try {
348 <            Thread.sleep(SHORT_DELAY_MS);
349 <            t.interrupt();
350 <            t.join();
351 <        } catch(Exception e) {
352 <            unexpectedException();
353 <        }
333 >    public void testTimedWait_Interruptible() {
334 >        final CountDownLatch pleaseInterrupt = new CountDownLatch(1);
335 >        Thread t = newStartedThread(new CheckedRunnable() {
336 >            public void realRun() throws InterruptedException {
337 >                Object o = new Object();
338 >                TimeUnit tu = MILLISECONDS;
339 >
340 >                Thread.currentThread().interrupt();
341 >                try {
342 >                    synchronized (o) {
343 >                        tu.timedWait(o, LONG_DELAY_MS);
344 >                    }
345 >                    shouldThrow();
346 >                } catch (InterruptedException success) {}
347 >                assertFalse(Thread.interrupted());
348 >
349 >                pleaseInterrupt.countDown();
350 >                try {
351 >                    synchronized (o) {
352 >                        tu.timedWait(o, LONG_DELAY_MS);
353 >                    }
354 >                    shouldThrow();
355 >                } catch (InterruptedException success) {}
356 >                assertFalse(Thread.interrupted());
357 >            }});
358 >
359 >        await(pleaseInterrupt);
360 >        assertThreadStaysAlive(t);
361 >        t.interrupt();
362 >        awaitTermination(t);
363      }
364  
365      /**
366 <     * a deserialized serialized unit is equal
366 >     * timedJoin throws InterruptedException when interrupted
367       */
368 <    public void testSerialization() {
369 <        TimeUnit q = TimeUnit.MILLISECONDS;
370 <
371 <        try {
372 <            ByteArrayOutputStream bout = new ByteArrayOutputStream(10000);
373 <            ObjectOutputStream out = new ObjectOutputStream(new BufferedOutputStream(bout));
374 <            out.writeObject(q);
375 <            out.close();
376 <
377 <            ByteArrayInputStream bin = new ByteArrayInputStream(bout.toByteArray());
378 <            ObjectInputStream in = new ObjectInputStream(new BufferedInputStream(bin));
379 <            TimeUnit r = (TimeUnit)in.readObject();
380 <            
381 <            assertEquals(q.toString(), r.toString());
382 <        } catch(Exception e){
383 <            e.printStackTrace();
384 <            unexpectedException();
368 >    public void testTimedJoin_Interruptible() {
369 >        final CountDownLatch pleaseInterrupt = new CountDownLatch(1);
370 >        final Thread s = newStartedThread(new CheckedInterruptedRunnable() {
371 >            public void realRun() throws InterruptedException {
372 >                Thread.sleep(LONG_DELAY_MS);
373 >            }});
374 >        final Thread t = newStartedThread(new CheckedRunnable() {
375 >            public void realRun() throws InterruptedException {
376 >                TimeUnit tu = MILLISECONDS;
377 >                Thread.currentThread().interrupt();
378 >                try {
379 >                    tu.timedJoin(s, LONG_DELAY_MS);
380 >                    shouldThrow();
381 >                } catch (InterruptedException success) {}
382 >                assertFalse(Thread.interrupted());
383 >
384 >                pleaseInterrupt.countDown();
385 >                try {
386 >                    tu.timedJoin(s, LONG_DELAY_MS);
387 >                    shouldThrow();
388 >                } catch (InterruptedException success) {}
389 >                assertFalse(Thread.interrupted());
390 >            }});
391 >
392 >        await(pleaseInterrupt);
393 >        assertThreadStaysAlive(t);
394 >        t.interrupt();
395 >        awaitTermination(t);
396 >        s.interrupt();
397 >        awaitTermination(s);
398 >    }
399 >
400 >    /**
401 >     * timedSleep throws InterruptedException when interrupted
402 >     */
403 >    public void testTimedSleep_Interruptible() {
404 >        final CountDownLatch pleaseInterrupt = new CountDownLatch(1);
405 >        Thread t = newStartedThread(new CheckedRunnable() {
406 >            public void realRun() throws InterruptedException {
407 >                TimeUnit tu = MILLISECONDS;
408 >                Thread.currentThread().interrupt();
409 >                try {
410 >                    tu.sleep(LONG_DELAY_MS);
411 >                    shouldThrow();
412 >                } catch (InterruptedException success) {}
413 >                assertFalse(Thread.interrupted());
414 >
415 >                pleaseInterrupt.countDown();
416 >                try {
417 >                    tu.sleep(LONG_DELAY_MS);
418 >                    shouldThrow();
419 >                } catch (InterruptedException success) {}
420 >                assertFalse(Thread.interrupted());
421 >            }});
422 >
423 >        await(pleaseInterrupt);
424 >        assertThreadStaysAlive(t);
425 >        t.interrupt();
426 >        awaitTermination(t);
427 >    }
428 >
429 >    /**
430 >     * a deserialized serialized unit is the same instance
431 >     */
432 >    public void testSerialization() throws Exception {
433 >        for (TimeUnit x : TimeUnit.values())
434 >            assertSame(x, serialClone(x));
435 >    }
436 >
437 >    /**
438 >     * tests for toChronoUnit.
439 >     */
440 >    public void testToChronoUnit() throws Exception {
441 >        assertSame(ChronoUnit.NANOS,   NANOSECONDS.toChronoUnit());
442 >        assertSame(ChronoUnit.MICROS,  MICROSECONDS.toChronoUnit());
443 >        assertSame(ChronoUnit.MILLIS,  MILLISECONDS.toChronoUnit());
444 >        assertSame(ChronoUnit.SECONDS, SECONDS.toChronoUnit());
445 >        assertSame(ChronoUnit.MINUTES, MINUTES.toChronoUnit());
446 >        assertSame(ChronoUnit.HOURS,   HOURS.toChronoUnit());
447 >        assertSame(ChronoUnit.DAYS,    DAYS.toChronoUnit());
448 >
449 >        // Every TimeUnit has a defined ChronoUnit equivalent
450 >        for (TimeUnit x : TimeUnit.values())
451 >            assertSame(x, TimeUnit.of(x.toChronoUnit()));
452 >    }
453 >
454 >    /**
455 >     * tests for TimeUnit.of(ChronoUnit).
456 >     */
457 >    public void testTimeUnitOf() throws Exception {
458 >        assertSame(NANOSECONDS,  TimeUnit.of(ChronoUnit.NANOS));
459 >        assertSame(MICROSECONDS, TimeUnit.of(ChronoUnit.MICROS));
460 >        assertSame(MILLISECONDS, TimeUnit.of(ChronoUnit.MILLIS));
461 >        assertSame(SECONDS,      TimeUnit.of(ChronoUnit.SECONDS));
462 >        assertSame(MINUTES,      TimeUnit.of(ChronoUnit.MINUTES));
463 >        assertSame(HOURS,        TimeUnit.of(ChronoUnit.HOURS));
464 >        assertSame(DAYS,         TimeUnit.of(ChronoUnit.DAYS));
465 >
466 >        assertThrows(NullPointerException.class,
467 >                     () -> TimeUnit.of((ChronoUnit)null));
468 >
469 >        // ChronoUnits either round trip to their TimeUnit
470 >        // equivalents, or throw IllegalArgumentException.
471 >        for (ChronoUnit cu : ChronoUnit.values()) {
472 >            final TimeUnit tu;
473 >            try {
474 >                tu = TimeUnit.of(cu);
475 >            } catch (IllegalArgumentException acceptable) {
476 >                continue;
477 >            }
478 >            assertSame(cu, tu.toChronoUnit());
479          }
480      }
481  

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines