480 |
|
new CustomTPE(THREADS, THREADS, |
481 |
|
LONG_DELAY_MS, MILLISECONDS, |
482 |
|
new ArrayBlockingQueue<Runnable>(10)); |
483 |
< |
final CountDownLatch threadsStarted = new CountDownLatch(THREADS); |
484 |
< |
final CountDownLatch done = new CountDownLatch(1); |
485 |
< |
try { |
483 |
> |
try (PoolCleaner cleaner = cleaner(p)) { |
484 |
> |
final CountDownLatch threadsStarted = new CountDownLatch(THREADS); |
485 |
> |
final CountDownLatch done = new CountDownLatch(1); |
486 |
|
assertEquals(0, p.getLargestPoolSize()); |
487 |
|
for (int i = 0; i < THREADS; i++) |
488 |
|
p.execute(new CheckedRunnable() { |
491 |
|
done.await(); |
492 |
|
assertEquals(THREADS, p.getLargestPoolSize()); |
493 |
|
}}); |
494 |
< |
assertTrue(threadsStarted.await(SMALL_DELAY_MS, MILLISECONDS)); |
495 |
< |
assertEquals(THREADS, p.getLargestPoolSize()); |
496 |
< |
} finally { |
497 |
< |
done.countDown(); |
498 |
< |
joinPool(p); |
494 |
> |
assertTrue(threadsStarted.await(MEDIUM_DELAY_MS, MILLISECONDS)); |
495 |
|
assertEquals(THREADS, p.getLargestPoolSize()); |
496 |
+ |
done.countDown(); // release pool |
497 |
|
} |
498 |
+ |
assertEquals(THREADS, p.getLargestPoolSize()); |
499 |
|
} |
500 |
|
|
501 |
|
/** |
503 |
|
* otherwise set |
504 |
|
*/ |
505 |
|
public void testGetMaximumPoolSize() { |
506 |
< |
ThreadPoolExecutor p = new CustomTPE(2, 2, LONG_DELAY_MS, MILLISECONDS, new ArrayBlockingQueue<Runnable>(10)); |
507 |
< |
assertEquals(2, p.getMaximumPoolSize()); |
508 |
< |
joinPool(p); |
506 |
> |
final ThreadPoolExecutor p = |
507 |
> |
new CustomTPE(2, 3, |
508 |
> |
LONG_DELAY_MS, MILLISECONDS, |
509 |
> |
new ArrayBlockingQueue<Runnable>(10)); |
510 |
> |
try (PoolCleaner cleaner = cleaner(p)) { |
511 |
> |
assertEquals(3, p.getMaximumPoolSize()); |
512 |
> |
p.setMaximumPoolSize(5); |
513 |
> |
assertEquals(5, p.getMaximumPoolSize()); |
514 |
> |
p.setMaximumPoolSize(4); |
515 |
> |
assertEquals(4, p.getMaximumPoolSize()); |
516 |
> |
} |
517 |
|
} |
518 |
|
|
519 |
|
/** |
525 |
|
new CustomTPE(1, 1, |
526 |
|
LONG_DELAY_MS, MILLISECONDS, |
527 |
|
new ArrayBlockingQueue<Runnable>(10)); |
528 |
< |
final CountDownLatch threadStarted = new CountDownLatch(1); |
529 |
< |
final CountDownLatch done = new CountDownLatch(1); |
530 |
< |
try { |
528 |
> |
try (PoolCleaner cleaner = cleaner(p)) { |
529 |
> |
final CountDownLatch threadStarted = new CountDownLatch(1); |
530 |
> |
final CountDownLatch done = new CountDownLatch(1); |
531 |
|
assertEquals(0, p.getPoolSize()); |
532 |
|
p.execute(new CheckedRunnable() { |
533 |
|
public void realRun() throws InterruptedException { |
535 |
|
assertEquals(1, p.getPoolSize()); |
536 |
|
done.await(); |
537 |
|
}}); |
538 |
< |
assertTrue(threadStarted.await(SMALL_DELAY_MS, MILLISECONDS)); |
538 |
> |
assertTrue(threadStarted.await(MEDIUM_DELAY_MS, MILLISECONDS)); |
539 |
|
assertEquals(1, p.getPoolSize()); |
540 |
< |
} finally { |
535 |
< |
done.countDown(); |
536 |
< |
joinPool(p); |
540 |
> |
done.countDown(); // release pool |
541 |
|
} |
542 |
|
} |
543 |
|
|