Fixes #2451 - Review ReservedThreadExecutor.getAvailable().
Fixed by having getAvailable() returning _stack.size(). Signed-off-by: Simone Bordet <simone.bordet@gmail.com>
This commit is contained in:
parent
f36eba4577
commit
fac93fa7f8
|
@ -120,7 +120,7 @@ public class ReservedThreadExecutor extends AbstractLifeCycle implements TryExec
|
||||||
@ManagedAttribute(value = "available reserved threads", readonly = true)
|
@ManagedAttribute(value = "available reserved threads", readonly = true)
|
||||||
public int getAvailable()
|
public int getAvailable()
|
||||||
{
|
{
|
||||||
return _size.get();
|
return _stack.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ManagedAttribute(value = "pending reserved threads", readonly = true)
|
@ManagedAttribute(value = "pending reserved threads", readonly = true)
|
||||||
|
|
|
@ -18,13 +18,8 @@
|
||||||
|
|
||||||
package org.eclipse.jetty.util.thread;
|
package org.eclipse.jetty.util.thread;
|
||||||
|
|
||||||
import static org.hamcrest.Matchers.is;
|
|
||||||
import static org.junit.Assert.assertThat;
|
|
||||||
import static org.junit.Assert.assertTrue;
|
|
||||||
|
|
||||||
import java.util.ArrayDeque;
|
import java.util.ArrayDeque;
|
||||||
import java.util.Deque;
|
import java.util.Deque;
|
||||||
import java.util.Random;
|
|
||||||
import java.util.concurrent.CountDownLatch;
|
import java.util.concurrent.CountDownLatch;
|
||||||
import java.util.concurrent.Executor;
|
import java.util.concurrent.Executor;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
@ -36,6 +31,10 @@ import org.junit.Before;
|
||||||
import org.junit.Ignore;
|
import org.junit.Ignore;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import static org.hamcrest.Matchers.is;
|
||||||
|
import static org.junit.Assert.assertThat;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
public class ReservedThreadExecutorTest
|
public class ReservedThreadExecutorTest
|
||||||
{
|
{
|
||||||
private static final int SIZE = 2;
|
private static final int SIZE = 2;
|
||||||
|
@ -71,7 +70,7 @@ public class ReservedThreadExecutorTest
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testStarted() throws Exception
|
public void testStarted()
|
||||||
{
|
{
|
||||||
// Reserved threads are lazily started.
|
// Reserved threads are lazily started.
|
||||||
assertThat(_executor._queue.size(), is(0));
|
assertThat(_executor._queue.size(), is(0));
|
||||||
|
@ -167,19 +166,6 @@ public class ReservedThreadExecutorTest
|
||||||
assertThat(_reservedExecutor.getAvailable(),is(0));
|
assertThat(_reservedExecutor.getAvailable(),is(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void waitForNoPending() throws InterruptedException
|
|
||||||
{
|
|
||||||
long started = System.nanoTime();
|
|
||||||
while (_reservedExecutor.getPending() > 0)
|
|
||||||
{
|
|
||||||
long elapsed = System.nanoTime() - started;
|
|
||||||
if (elapsed > TimeUnit.SECONDS.toNanos(10))
|
|
||||||
Assert.fail("pending="+_reservedExecutor.getPending());
|
|
||||||
Thread.sleep(10);
|
|
||||||
}
|
|
||||||
assertThat(_reservedExecutor.getPending(), is(0));
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void waitForAvailable(int size) throws InterruptedException
|
protected void waitForAvailable(int size) throws InterruptedException
|
||||||
{
|
{
|
||||||
long started = System.nanoTime();
|
long started = System.nanoTime();
|
||||||
|
@ -248,7 +234,6 @@ public class ReservedThreadExecutorTest
|
||||||
reserved.start();
|
reserved.start();
|
||||||
|
|
||||||
final int LOOPS = 1000000;
|
final int LOOPS = 1000000;
|
||||||
final Random random = new Random();
|
|
||||||
final AtomicInteger executions = new AtomicInteger(LOOPS);
|
final AtomicInteger executions = new AtomicInteger(LOOPS);
|
||||||
final CountDownLatch executed = new CountDownLatch(executions.get());
|
final CountDownLatch executed = new CountDownLatch(executions.get());
|
||||||
final AtomicInteger usedReserved = new AtomicInteger(0);
|
final AtomicInteger usedReserved = new AtomicInteger(0);
|
||||||
|
|
Loading…
Reference in New Issue