305 |
|
} |
306 |
|
|
307 |
|
/** |
308 |
< |
* timed offer does not time out |
308 |
> |
* Queue is unbounded, so timed offer never times out |
309 |
|
*/ |
310 |
|
public void testTimedOffer() throws InterruptedException { |
311 |
|
final DelayQueue q = new DelayQueue(); |
409 |
|
final DelayQueue q = populatedQueue(SIZE); |
410 |
|
Thread t = newStartedThread(new CheckedRunnable() { |
411 |
|
public void realRun() throws InterruptedException { |
412 |
– |
long startTime = System.nanoTime(); |
412 |
|
for (int i = 0; i < SIZE; i++) |
413 |
|
assertEquals(new PDelay(i), |
414 |
|
((PDelay)q.poll(LONG_DELAY_MS, MILLISECONDS))); |
422 |
|
|
423 |
|
pleaseInterrupt.countDown(); |
424 |
|
try { |
425 |
< |
q.poll(LONG_DELAY_MS, MILLISECONDS); |
425 |
> |
q.poll(LONGER_DELAY_MS, MILLISECONDS); |
426 |
|
shouldThrow(); |
427 |
|
} catch (InterruptedException success) {} |
428 |
|
assertFalse(Thread.interrupted()); |
430 |
– |
|
431 |
– |
assertTrue(millisElapsedSince(startTime) < LONG_DELAY_MS); |
429 |
|
}}); |
430 |
|
|
431 |
|
await(pleaseInterrupt); |