Calling notIdle() to avoid the idle timeout triggers when sending frames.
This commit is contained in:
parent
9a1acd59fc
commit
8af9ea4030
|
@ -467,7 +467,7 @@ public class IdleTimeoutTest extends AbstractTest
|
|||
final Stream stream = promise.get(5, TimeUnit.SECONDS);
|
||||
|
||||
sleep(idleTimeout / 2);
|
||||
final CountDownLatch latch = new CountDownLatch(1);
|
||||
final CountDownLatch dataLatch = new CountDownLatch(1);
|
||||
stream.data(new DataFrame(stream.getId(), ByteBuffer.allocate(1), false), new Callback.Adapter()
|
||||
{
|
||||
private int sends;
|
||||
|
@ -482,16 +482,62 @@ public class IdleTimeoutTest extends AbstractTest
|
|||
@Override
|
||||
public void succeeded()
|
||||
{
|
||||
latch.countDown();
|
||||
dataLatch.countDown();
|
||||
}
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
Assert.assertTrue(latch.await(2 * idleTimeout, TimeUnit.MILLISECONDS));
|
||||
Assert.assertTrue(dataLatch.await(2 * idleTimeout, TimeUnit.MILLISECONDS));
|
||||
Assert.assertFalse(timeoutLatch.await(0, TimeUnit.SECONDS));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testStreamIdleTimeoutIsNotEnforcedWhenSending() throws Exception
|
||||
{
|
||||
final CountDownLatch resetLatch = new CountDownLatch(1);
|
||||
startServer(new ServerSessionListener.Adapter()
|
||||
{
|
||||
@Override
|
||||
public Stream.Listener onNewStream(Stream stream, HeadersFrame frame)
|
||||
{
|
||||
MetaData.Response response = new MetaData.Response(HttpVersion.HTTP_2, 200, new HttpFields());
|
||||
stream.headers(new HeadersFrame(stream.getId(), response, null, true), Callback.Adapter.INSTANCE);
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onReset(Session session, ResetFrame frame)
|
||||
{
|
||||
resetLatch.countDown();
|
||||
}
|
||||
});
|
||||
|
||||
Session session = newClient(new Session.Listener.Adapter());
|
||||
MetaData.Request metaData = newRequest("GET", new HttpFields());
|
||||
HeadersFrame requestFrame = new HeadersFrame(0, metaData, null, false);
|
||||
FuturePromise<Stream> promise = new FuturePromise<Stream>()
|
||||
{
|
||||
@Override
|
||||
public void succeeded(Stream stream)
|
||||
{
|
||||
stream.setIdleTimeout(idleTimeout);
|
||||
super.succeeded(stream);
|
||||
}
|
||||
};
|
||||
session.newStream(requestFrame, promise, new Stream.Listener.Adapter());
|
||||
final Stream stream = promise.get(5, TimeUnit.SECONDS);
|
||||
|
||||
sleep(idleTimeout / 2);
|
||||
stream.data(new DataFrame(stream.getId(), ByteBuffer.allocate(1), false), Callback.Adapter.INSTANCE);
|
||||
sleep(idleTimeout / 2);
|
||||
stream.data(new DataFrame(stream.getId(), ByteBuffer.allocate(1), false), Callback.Adapter.INSTANCE);
|
||||
sleep(idleTimeout / 2);
|
||||
stream.data(new DataFrame(stream.getId(), ByteBuffer.allocate(1), true), Callback.Adapter.INSTANCE);
|
||||
|
||||
Assert.assertFalse(resetLatch.await(0, TimeUnit.SECONDS));
|
||||
}
|
||||
|
||||
private void sleep(long value)
|
||||
{
|
||||
try
|
||||
|
|
|
@ -72,24 +72,28 @@ public class HTTP2Stream extends IdleTimeout implements IStream
|
|||
@Override
|
||||
public void headers(HeadersFrame frame, Callback callback)
|
||||
{
|
||||
notIdle();
|
||||
session.control(this, callback, frame, Frame.EMPTY_ARRAY);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void push(PushPromiseFrame frame, Promise<Stream> promise)
|
||||
{
|
||||
notIdle();
|
||||
session.push(this, promise, frame);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void data(DataFrame frame, Callback callback)
|
||||
{
|
||||
notIdle();
|
||||
session.data(this, callback, frame);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void reset(ResetFrame frame, Callback callback)
|
||||
{
|
||||
notIdle();
|
||||
session.control(this, callback, frame, Frame.EMPTY_ARRAY);
|
||||
}
|
||||
|
||||
|
@ -176,10 +180,39 @@ public class HTTP2Stream extends IdleTimeout implements IStream
|
|||
public boolean process(Frame frame, Callback callback)
|
||||
{
|
||||
notIdle();
|
||||
|
||||
switch (frame.getType())
|
||||
{
|
||||
case HEADERS:
|
||||
{
|
||||
return onHeaders((HeadersFrame)frame, callback);
|
||||
}
|
||||
case DATA:
|
||||
{
|
||||
return onData((DataFrame)frame, callback);
|
||||
}
|
||||
case RST_STREAM:
|
||||
{
|
||||
return onReset((ResetFrame)frame, callback);
|
||||
}
|
||||
case PUSH_PROMISE:
|
||||
{
|
||||
return onPush((PushPromiseFrame)frame, callback);
|
||||
}
|
||||
default:
|
||||
{
|
||||
throw new UnsupportedOperationException();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private boolean onHeaders(HeadersFrame frame, Callback callback)
|
||||
{
|
||||
// TODO: handle case where HEADERS after DATA.
|
||||
callback.succeeded();
|
||||
return false;
|
||||
}
|
||||
|
||||
private boolean onData(DataFrame frame, Callback callback)
|
||||
{
|
||||
// TODO: handle cases where:
|
||||
// TODO: A) stream already remotely close.
|
||||
|
@ -190,32 +223,27 @@ public class HTTP2Stream extends IdleTimeout implements IStream
|
|||
// It's a bad client, it does not deserve to be
|
||||
// treated gently by just resetting the stream.
|
||||
session.close(ErrorCodes.FLOW_CONTROL_ERROR, "stream_window_exceeded", callback);
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
notifyData(this, frame, callback);
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
private boolean onReset(ResetFrame frame, Callback callback)
|
||||
{
|
||||
reset = true;
|
||||
callback.succeeded();
|
||||
return false;
|
||||
}
|
||||
|
||||
notifyData(this, (DataFrame)frame, callback);
|
||||
return false;
|
||||
}
|
||||
case HEADERS:
|
||||
private boolean onPush(PushPromiseFrame frame, Callback callback)
|
||||
{
|
||||
// TODO: handle case where HEADERS after DATA.
|
||||
callback.succeeded();
|
||||
return false;
|
||||
}
|
||||
case RST_STREAM:
|
||||
{
|
||||
reset = true;
|
||||
return false;
|
||||
}
|
||||
case PUSH_PROMISE:
|
||||
{
|
||||
return false;
|
||||
}
|
||||
default:
|
||||
{
|
||||
throw new UnsupportedOperationException();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateClose(boolean update, boolean local)
|
||||
|
|
Loading…
Reference in New Issue