use of org.apache.flink.shaded.netty4.io.netty.channel.embedded.EmbeddedChannel in project jocean-http by isdom.
the class DefaultHttpTradeTestCase method testTradeForResponseAfterAbort.
@Test
public final void testTradeForResponseAfterAbort() {
final HttpTrade trade = new DefaultHttpTrade(new EmbeddedChannel());
trade.close();
assertFalse(trade.isActive());
final SubscriberHolder<HttpObject> subsholder = new SubscriberHolder<>();
final Subscription subscription = trade.outbound(Observable.unsafeCreate(subsholder));
assertNull(subscription);
assertEquals(0, subsholder.getSubscriberCount());
}
use of org.apache.flink.shaded.netty4.io.netty.channel.embedded.EmbeddedChannel in project jocean-http by isdom.
the class DefaultHttpTradeTestCase method testDoOnClosedBeforeAndAfterOutboundResponse.
@Test
public final void testDoOnClosedBeforeAndAfterOutboundResponse() {
final HttpTrade trade = new DefaultHttpTrade(new EmbeddedChannel());
final AtomicBoolean onClosed = new AtomicBoolean(false);
trade.doOnTerminate(new Action1<HttpTrade>() {
@Override
public void call(final HttpTrade trade) {
onClosed.set(true);
}
});
assertFalse(onClosed.get());
assertTrue(trade.isActive());
trade.outbound(Observable.<HttpObject>error(new RuntimeException("ResponseError")));
assertFalse(trade.isActive());
assertTrue(onClosed.get());
}
use of org.apache.flink.shaded.netty4.io.netty.channel.embedded.EmbeddedChannel in project jocean-http by isdom.
the class DefaultHttpTradeTestCase method testTradeForRequestAndContentsSourceAndDumpFullRequests.
@Test
public final void testTradeForRequestAndContentsSourceAndDumpFullRequests() throws IOException {
final DefaultHttpRequest request = new DefaultHttpRequest(HttpVersion.HTTP_1_1, HttpMethod.POST, "/");
final HttpContent[] req_contents = Nettys4Test.buildContentArray(REQ_CONTENT.getBytes(Charsets.UTF_8), 1);
final EmbeddedChannel channel = new EmbeddedChannel();
final HttpTrade trade = new DefaultHttpTrade(channel);
Observable.<HttpObject>concat(Observable.<HttpObject>just(request), Observable.<HttpObject>from(req_contents), Observable.<HttpObject>just(LastHttpContent.EMPTY_LAST_CONTENT)).map(obj -> writeToInboundAndFlush(channel, obj)).last().toBlocking().single().syncUninterruptibly();
callByteBufHolderBuilderOnceAndAssertDumpContentAndRefCnt(trade.inbound().compose(RxNettys.message2fullreq(trade)).toBlocking().single().unwrap(), REQ_CONTENT.getBytes(Charsets.UTF_8), 1);
callByteBufHolderBuilderOnceAndAssertDumpContentAndRefCnt(trade.inbound().compose(RxNettys.message2fullreq(trade)).toBlocking().single().unwrap(), REQ_CONTENT.getBytes(Charsets.UTF_8), 1);
}
use of org.apache.flink.shaded.netty4.io.netty.channel.embedded.EmbeddedChannel in project jocean-http by isdom.
the class DefaultHttpTradeTestCase method testTradeForMultiSubscribeRequestOnlyOneToSource2.
// 3 subscriber subscribe inbound request at different time,
// so push with different httpobject
@Test
public final void testTradeForMultiSubscribeRequestOnlyOneToSource2() {
final DefaultHttpRequest request = new DefaultHttpRequest(HttpVersion.HTTP_1_1, HttpMethod.POST, "/");
final HttpContent[] req_contents = Nettys4Test.buildContentArray(REQ_CONTENT.getBytes(Charsets.UTF_8), 1);
final EmbeddedChannel channel = new EmbeddedChannel();
final HttpTrade trade = new DefaultHttpTrade(channel);
// trade.inboundHolder().setMaxBlockSize(-1);
final TestSubscriber<DisposableWrapper<HttpObject>> reqSubscriber1 = new TestSubscriber<>();
trade.inbound().subscribe(reqSubscriber1);
writeToInboundAndFlush(channel, request);
reqSubscriber1.assertValueCount(1);
reqSubscriber1.assertValues(RxNettys.<HttpObject>wrap4release(request));
final TestSubscriber<DisposableWrapper<HttpObject>> reqSubscriber2 = new TestSubscriber<>();
trade.inbound().subscribe(reqSubscriber2);
writeToInboundAndFlush(channel, req_contents[0]);
reqSubscriber1.assertValueCount(2);
reqSubscriber1.assertValues(RxNettys.<HttpObject>wrap4release(request), RxNettys.<HttpObject>wrap4release(req_contents[0]));
reqSubscriber2.assertValueCount(2);
reqSubscriber2.assertValues(RxNettys.<HttpObject>wrap4release(request), RxNettys.<HttpObject>wrap4release(req_contents[0]));
final TestSubscriber<DisposableWrapper<HttpObject>> reqSubscriber3 = new TestSubscriber<>();
trade.inbound().subscribe(reqSubscriber3);
reqSubscriber1.assertValueCount(2);
reqSubscriber1.assertValues(RxNettys.<HttpObject>wrap4release(request), RxNettys.<HttpObject>wrap4release(req_contents[0]));
reqSubscriber2.assertValueCount(2);
reqSubscriber2.assertValues(RxNettys.<HttpObject>wrap4release(request), RxNettys.<HttpObject>wrap4release(req_contents[0]));
reqSubscriber3.assertValueCount(2);
reqSubscriber3.assertValues(RxNettys.<HttpObject>wrap4release(request), RxNettys.<HttpObject>wrap4release(req_contents[0]));
}
use of org.apache.flink.shaded.netty4.io.netty.channel.embedded.EmbeddedChannel in project jocean-http by isdom.
the class ChannelTestCase method testChannelInactiveForInactiveChannel.
@Test
public final void testChannelInactiveForInactiveChannel() throws InterruptedException {
final EmbeddedChannel channel = new EmbeddedChannel();
channel.disconnect().syncUninterruptibly();
assertTrue(!channel.isActive());
final AtomicBoolean isInactiveCalled = new AtomicBoolean(false);
channel.pipeline().addLast(new ChannelInboundHandlerAdapter() {
@Override
public void channelInactive(final ChannelHandlerContext ctx) throws Exception {
isInactiveCalled.set(true);
}
});
Thread.currentThread().sleep(1000);
assertFalse(isInactiveCalled.get());
}
Aggregations