Merge pull request #4539 from eclipse/jetty-10.0.x-4501-SharedBlockingCallback
Issue #4501 - remove all SharedBlockingCallback usage from websocket
This commit is contained in:
commit
41a7b8d4e3
|
@ -25,7 +25,7 @@ import java.nio.ByteBuffer;
|
||||||
import org.eclipse.jetty.io.ByteBufferPool;
|
import org.eclipse.jetty.io.ByteBufferPool;
|
||||||
import org.eclipse.jetty.util.BufferUtil;
|
import org.eclipse.jetty.util.BufferUtil;
|
||||||
import org.eclipse.jetty.util.Callback;
|
import org.eclipse.jetty.util.Callback;
|
||||||
import org.eclipse.jetty.util.SharedBlockingCallback;
|
import org.eclipse.jetty.util.FutureCallback;
|
||||||
import org.eclipse.jetty.util.log.Log;
|
import org.eclipse.jetty.util.log.Log;
|
||||||
import org.eclipse.jetty.util.log.Logger;
|
import org.eclipse.jetty.util.log.Logger;
|
||||||
import org.eclipse.jetty.websocket.core.CoreSession;
|
import org.eclipse.jetty.websocket.core.CoreSession;
|
||||||
|
@ -41,7 +41,6 @@ public class MessageOutputStream extends OutputStream
|
||||||
|
|
||||||
private final CoreSession coreSession;
|
private final CoreSession coreSession;
|
||||||
private final ByteBufferPool bufferPool;
|
private final ByteBufferPool bufferPool;
|
||||||
private final SharedBlockingCallback blocker;
|
|
||||||
private long frameCount;
|
private long frameCount;
|
||||||
private long bytesSent;
|
private long bytesSent;
|
||||||
private Frame frame;
|
private Frame frame;
|
||||||
|
@ -53,7 +52,6 @@ public class MessageOutputStream extends OutputStream
|
||||||
{
|
{
|
||||||
this.coreSession = coreSession;
|
this.coreSession = coreSession;
|
||||||
this.bufferPool = bufferPool;
|
this.bufferPool = bufferPool;
|
||||||
this.blocker = new SharedBlockingCallback();
|
|
||||||
this.buffer = bufferPool.acquire(bufferSize, true);
|
this.buffer = bufferPool.acquire(bufferSize, true);
|
||||||
BufferUtil.flipToFill(buffer);
|
BufferUtil.flipToFill(buffer);
|
||||||
this.frame = new Frame(OpCode.BINARY);
|
this.frame = new Frame(OpCode.BINARY);
|
||||||
|
@ -118,11 +116,9 @@ public class MessageOutputStream extends OutputStream
|
||||||
frame.setFin(fin);
|
frame.setFin(fin);
|
||||||
|
|
||||||
int initialBufferSize = buffer.remaining();
|
int initialBufferSize = buffer.remaining();
|
||||||
try (SharedBlockingCallback.Blocker b = blocker.acquire())
|
FutureCallback b = new FutureCallback();
|
||||||
{
|
coreSession.sendFrame(frame, b, false);
|
||||||
coreSession.sendFrame(frame, b, false);
|
b.block();
|
||||||
b.block();
|
|
||||||
}
|
|
||||||
|
|
||||||
++frameCount;
|
++frameCount;
|
||||||
// Any flush after the first will be a CONTINUATION frame.
|
// Any flush after the first will be a CONTINUATION frame.
|
||||||
|
|
|
@ -27,7 +27,7 @@ import java.nio.charset.CodingErrorAction;
|
||||||
|
|
||||||
import org.eclipse.jetty.util.BufferUtil;
|
import org.eclipse.jetty.util.BufferUtil;
|
||||||
import org.eclipse.jetty.util.Callback;
|
import org.eclipse.jetty.util.Callback;
|
||||||
import org.eclipse.jetty.util.SharedBlockingCallback;
|
import org.eclipse.jetty.util.FutureCallback;
|
||||||
import org.eclipse.jetty.util.log.Log;
|
import org.eclipse.jetty.util.log.Log;
|
||||||
import org.eclipse.jetty.util.log.Logger;
|
import org.eclipse.jetty.util.log.Logger;
|
||||||
import org.eclipse.jetty.websocket.core.CoreSession;
|
import org.eclipse.jetty.websocket.core.CoreSession;
|
||||||
|
@ -50,7 +50,6 @@ public class MessageWriter extends Writer
|
||||||
.onMalformedInput(CodingErrorAction.REPORT);
|
.onMalformedInput(CodingErrorAction.REPORT);
|
||||||
|
|
||||||
private final CoreSession coreSession;
|
private final CoreSession coreSession;
|
||||||
private final SharedBlockingCallback blocker;
|
|
||||||
private long frameCount;
|
private long frameCount;
|
||||||
private Frame frame;
|
private Frame frame;
|
||||||
private CharBuffer buffer;
|
private CharBuffer buffer;
|
||||||
|
@ -60,7 +59,6 @@ public class MessageWriter extends Writer
|
||||||
public MessageWriter(CoreSession coreSession, int bufferSize)
|
public MessageWriter(CoreSession coreSession, int bufferSize)
|
||||||
{
|
{
|
||||||
this.coreSession = coreSession;
|
this.coreSession = coreSession;
|
||||||
this.blocker = new SharedBlockingCallback();
|
|
||||||
this.buffer = CharBuffer.allocate(bufferSize);
|
this.buffer = CharBuffer.allocate(bufferSize);
|
||||||
this.frame = new Frame(OpCode.TEXT);
|
this.frame = new Frame(OpCode.TEXT);
|
||||||
}
|
}
|
||||||
|
@ -128,11 +126,9 @@ public class MessageWriter extends Writer
|
||||||
frame.setPayload(payload);
|
frame.setPayload(payload);
|
||||||
frame.setFin(fin);
|
frame.setFin(fin);
|
||||||
|
|
||||||
try (SharedBlockingCallback.Blocker b = blocker.acquire())
|
FutureCallback b = new FutureCallback();
|
||||||
{
|
coreSession.sendFrame(frame, b, false);
|
||||||
coreSession.sendFrame(frame, b, false);
|
b.block();
|
||||||
b.block();
|
|
||||||
}
|
|
||||||
|
|
||||||
++frameCount;
|
++frameCount;
|
||||||
// Any flush after the first will be a CONTINUATION frame.
|
// Any flush after the first will be a CONTINUATION frame.
|
||||||
|
|
|
@ -21,6 +21,7 @@ package org.eclipse.jetty.websocket.javax.tests;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.URI;
|
import java.net.URI;
|
||||||
import java.nio.ByteBuffer;
|
import java.nio.ByteBuffer;
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.concurrent.BlockingQueue;
|
import java.util.concurrent.BlockingQueue;
|
||||||
|
@ -33,7 +34,7 @@ import org.eclipse.jetty.http.HttpFields;
|
||||||
import org.eclipse.jetty.io.EndPoint;
|
import org.eclipse.jetty.io.EndPoint;
|
||||||
import org.eclipse.jetty.util.BufferUtil;
|
import org.eclipse.jetty.util.BufferUtil;
|
||||||
import org.eclipse.jetty.util.Callback;
|
import org.eclipse.jetty.util.Callback;
|
||||||
import org.eclipse.jetty.util.SharedBlockingCallback;
|
import org.eclipse.jetty.util.FutureCallback;
|
||||||
import org.eclipse.jetty.websocket.core.Behavior;
|
import org.eclipse.jetty.websocket.core.Behavior;
|
||||||
import org.eclipse.jetty.websocket.core.CloseStatus;
|
import org.eclipse.jetty.websocket.core.CloseStatus;
|
||||||
import org.eclipse.jetty.websocket.core.CoreSession;
|
import org.eclipse.jetty.websocket.core.CoreSession;
|
||||||
|
@ -52,7 +53,6 @@ public class NetworkFuzzer extends Fuzzer.Adapter implements Fuzzer, AutoCloseab
|
||||||
private final RawUpgradeRequest upgradeRequest;
|
private final RawUpgradeRequest upgradeRequest;
|
||||||
private final UnitGenerator generator;
|
private final UnitGenerator generator;
|
||||||
private final FrameCapture frameCapture;
|
private final FrameCapture frameCapture;
|
||||||
private SharedBlockingCallback sharedBlockingCallback = new SharedBlockingCallback();
|
|
||||||
|
|
||||||
public NetworkFuzzer(LocalServer server) throws Exception
|
public NetworkFuzzer(LocalServer server) throws Exception
|
||||||
{
|
{
|
||||||
|
@ -155,23 +155,16 @@ public class NetworkFuzzer extends Fuzzer.Adapter implements Fuzzer, AutoCloseab
|
||||||
{
|
{
|
||||||
for (Frame f : frames)
|
for (Frame f : frames)
|
||||||
{
|
{
|
||||||
try (SharedBlockingCallback.Blocker blocker = sharedBlockingCallback.acquire())
|
FutureCallback callback = new FutureCallback();
|
||||||
{
|
frameCapture.coreSession.sendFrame(f, callback, false);
|
||||||
frameCapture.coreSession.sendFrame(f, blocker, false);
|
callback.block();
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void sendFrames(Frame... frames) throws IOException
|
public void sendFrames(Frame... frames) throws IOException
|
||||||
{
|
{
|
||||||
for (Frame f : frames)
|
sendFrames(Arrays.asList(frames));
|
||||||
{
|
|
||||||
try (SharedBlockingCallback.Blocker blocker = sharedBlockingCallback.acquire())
|
|
||||||
{
|
|
||||||
frameCapture.coreSession.sendFrame(f, blocker, false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -227,7 +220,6 @@ public class NetworkFuzzer extends Fuzzer.Adapter implements Fuzzer, AutoCloseab
|
||||||
private final BlockingQueue<Frame> receivedFrames = new LinkedBlockingQueue<>();
|
private final BlockingQueue<Frame> receivedFrames = new LinkedBlockingQueue<>();
|
||||||
private EndPoint endPoint;
|
private EndPoint endPoint;
|
||||||
private CountDownLatch openLatch = new CountDownLatch(1);
|
private CountDownLatch openLatch = new CountDownLatch(1);
|
||||||
private final SharedBlockingCallback blockingCallback = new SharedBlockingCallback();
|
|
||||||
private CoreSession coreSession;
|
private CoreSession coreSession;
|
||||||
|
|
||||||
public void setEndPoint(EndPoint endpoint)
|
public void setEndPoint(EndPoint endpoint)
|
||||||
|
@ -275,10 +267,9 @@ public class NetworkFuzzer extends Fuzzer.Adapter implements Fuzzer, AutoCloseab
|
||||||
|
|
||||||
synchronized (this)
|
synchronized (this)
|
||||||
{
|
{
|
||||||
try (SharedBlockingCallback.Blocker blocker = blockingCallback.acquire())
|
FutureCallback callback = new FutureCallback();
|
||||||
{
|
endPoint.write(callback, buffer);
|
||||||
endPoint.write(blocker, buffer);
|
callback.block();
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,6 +18,8 @@
|
||||||
|
|
||||||
package org.eclipse.jetty.websocket.javax.tests.server;
|
package org.eclipse.jetty.websocket.javax.tests.server;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.nio.channels.ClosedChannelException;
|
||||||
import java.util.concurrent.BlockingQueue;
|
import java.util.concurrent.BlockingQueue;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
|
@ -38,7 +40,9 @@ import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
import static org.hamcrest.MatcherAssert.assertThat;
|
import static org.hamcrest.MatcherAssert.assertThat;
|
||||||
import static org.hamcrest.Matchers.containsString;
|
import static org.hamcrest.Matchers.containsString;
|
||||||
|
import static org.hamcrest.Matchers.instanceOf;
|
||||||
import static org.hamcrest.Matchers.is;
|
import static org.hamcrest.Matchers.is;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertThrows;
|
||||||
|
|
||||||
public class IdleTimeoutTest
|
public class IdleTimeoutTest
|
||||||
{
|
{
|
||||||
|
@ -76,7 +80,9 @@ public class IdleTimeoutTest
|
||||||
// wait 1 second to allow timeout to fire off
|
// wait 1 second to allow timeout to fire off
|
||||||
TimeUnit.SECONDS.sleep(1);
|
TimeUnit.SECONDS.sleep(1);
|
||||||
|
|
||||||
session.sendFrames(new Frame(OpCode.TEXT).setPayload("You shouldn't be there"));
|
IOException error = assertThrows(IOException.class,
|
||||||
|
() -> session.sendFrames(new Frame(OpCode.TEXT).setPayload("You shouldn't be there")));
|
||||||
|
assertThat(error.getCause(), instanceOf(ClosedChannelException.class));
|
||||||
|
|
||||||
BlockingQueue<Frame> framesQueue = session.getOutputFrames();
|
BlockingQueue<Frame> framesQueue = session.getOutputFrames();
|
||||||
Frame frame = framesQueue.poll(1, TimeUnit.SECONDS);
|
Frame frame = framesQueue.poll(1, TimeUnit.SECONDS);
|
||||||
|
|
|
@ -25,7 +25,7 @@ import java.nio.ByteBuffer;
|
||||||
import org.eclipse.jetty.io.ByteBufferPool;
|
import org.eclipse.jetty.io.ByteBufferPool;
|
||||||
import org.eclipse.jetty.util.BufferUtil;
|
import org.eclipse.jetty.util.BufferUtil;
|
||||||
import org.eclipse.jetty.util.Callback;
|
import org.eclipse.jetty.util.Callback;
|
||||||
import org.eclipse.jetty.util.SharedBlockingCallback;
|
import org.eclipse.jetty.util.FutureCallback;
|
||||||
import org.eclipse.jetty.util.log.Log;
|
import org.eclipse.jetty.util.log.Log;
|
||||||
import org.eclipse.jetty.util.log.Logger;
|
import org.eclipse.jetty.util.log.Logger;
|
||||||
import org.eclipse.jetty.websocket.core.CoreSession;
|
import org.eclipse.jetty.websocket.core.CoreSession;
|
||||||
|
@ -41,7 +41,6 @@ public class MessageOutputStream extends OutputStream
|
||||||
|
|
||||||
private final CoreSession coreSession;
|
private final CoreSession coreSession;
|
||||||
private final ByteBufferPool bufferPool;
|
private final ByteBufferPool bufferPool;
|
||||||
private final SharedBlockingCallback blocker;
|
|
||||||
private long frameCount;
|
private long frameCount;
|
||||||
private long bytesSent;
|
private long bytesSent;
|
||||||
private Frame frame;
|
private Frame frame;
|
||||||
|
@ -53,7 +52,6 @@ public class MessageOutputStream extends OutputStream
|
||||||
{
|
{
|
||||||
this.coreSession = coreSession;
|
this.coreSession = coreSession;
|
||||||
this.bufferPool = bufferPool;
|
this.bufferPool = bufferPool;
|
||||||
this.blocker = new SharedBlockingCallback();
|
|
||||||
this.buffer = bufferPool.acquire(bufferSize, true);
|
this.buffer = bufferPool.acquire(bufferSize, true);
|
||||||
BufferUtil.flipToFill(buffer);
|
BufferUtil.flipToFill(buffer);
|
||||||
this.frame = new Frame(OpCode.BINARY);
|
this.frame = new Frame(OpCode.BINARY);
|
||||||
|
@ -116,8 +114,10 @@ public class MessageOutputStream extends OutputStream
|
||||||
BufferUtil.flipToFlush(buffer, 0);
|
BufferUtil.flipToFlush(buffer, 0);
|
||||||
frame.setPayload(buffer);
|
frame.setPayload(buffer);
|
||||||
frame.setFin(fin);
|
frame.setFin(fin);
|
||||||
try (SharedBlockingCallback.Blocker b = blocker.acquire())
|
|
||||||
|
try
|
||||||
{
|
{
|
||||||
|
FutureCallback b = new FutureCallback();
|
||||||
coreSession.sendFrame(frame, b, false);
|
coreSession.sendFrame(frame, b, false);
|
||||||
b.block();
|
b.block();
|
||||||
assert buffer.remaining() == 0;
|
assert buffer.remaining() == 0;
|
||||||
|
|
|
@ -27,7 +27,7 @@ import java.nio.charset.CodingErrorAction;
|
||||||
|
|
||||||
import org.eclipse.jetty.util.BufferUtil;
|
import org.eclipse.jetty.util.BufferUtil;
|
||||||
import org.eclipse.jetty.util.Callback;
|
import org.eclipse.jetty.util.Callback;
|
||||||
import org.eclipse.jetty.util.SharedBlockingCallback;
|
import org.eclipse.jetty.util.FutureCallback;
|
||||||
import org.eclipse.jetty.util.log.Log;
|
import org.eclipse.jetty.util.log.Log;
|
||||||
import org.eclipse.jetty.util.log.Logger;
|
import org.eclipse.jetty.util.log.Logger;
|
||||||
import org.eclipse.jetty.websocket.core.CoreSession;
|
import org.eclipse.jetty.websocket.core.CoreSession;
|
||||||
|
@ -50,7 +50,6 @@ public class MessageWriter extends Writer
|
||||||
.onMalformedInput(CodingErrorAction.REPORT);
|
.onMalformedInput(CodingErrorAction.REPORT);
|
||||||
|
|
||||||
private final CoreSession coreSession;
|
private final CoreSession coreSession;
|
||||||
private final SharedBlockingCallback blocker;
|
|
||||||
private long frameCount;
|
private long frameCount;
|
||||||
private Frame frame;
|
private Frame frame;
|
||||||
private CharBuffer buffer;
|
private CharBuffer buffer;
|
||||||
|
@ -60,7 +59,6 @@ public class MessageWriter extends Writer
|
||||||
public MessageWriter(CoreSession coreSession, int bufferSize)
|
public MessageWriter(CoreSession coreSession, int bufferSize)
|
||||||
{
|
{
|
||||||
this.coreSession = coreSession;
|
this.coreSession = coreSession;
|
||||||
this.blocker = new SharedBlockingCallback();
|
|
||||||
this.buffer = CharBuffer.allocate(bufferSize);
|
this.buffer = CharBuffer.allocate(bufferSize);
|
||||||
this.frame = new Frame(OpCode.TEXT);
|
this.frame = new Frame(OpCode.TEXT);
|
||||||
}
|
}
|
||||||
|
@ -128,11 +126,9 @@ public class MessageWriter extends Writer
|
||||||
frame.setPayload(payload);
|
frame.setPayload(payload);
|
||||||
frame.setFin(fin);
|
frame.setFin(fin);
|
||||||
|
|
||||||
try (SharedBlockingCallback.Blocker b = blocker.acquire())
|
FutureCallback b = new FutureCallback();
|
||||||
{
|
coreSession.sendFrame(frame, b, false);
|
||||||
coreSession.sendFrame(frame, b, false);
|
b.block();
|
||||||
b.block();
|
|
||||||
}
|
|
||||||
|
|
||||||
++frameCount;
|
++frameCount;
|
||||||
// Any flush after the first will be a CONTINUATION frame.
|
// Any flush after the first will be a CONTINUATION frame.
|
||||||
|
|
Loading…
Reference in New Issue