Search in sources :

Example 1 with Interface

use of org.apache.hadoop.hbase.shaded.ipc.protobuf.generated.TestRpcServiceProtos.TestProtobufRpcProto.Interface in project hbase by apache.

the class AbstractTestIPC method testAsyncEcho.

@Test
public void testAsyncEcho() throws IOException {
    Configuration conf = HBaseConfiguration.create();
    RpcServer rpcServer = createRpcServer(null, "testRpcServer", Lists.newArrayList(new RpcServer.BlockingServiceAndInterface(SERVICE, null)), new InetSocketAddress("localhost", 0), CONF, new FifoRpcScheduler(CONF, 1));
    try (AbstractRpcClient<?> client = createRpcClient(conf)) {
        rpcServer.start();
        Interface stub = newStub(client, rpcServer.getListenerAddress());
        int num = 10;
        List<HBaseRpcController> pcrcList = new ArrayList<>();
        List<BlockingRpcCallback<EchoResponseProto>> callbackList = new ArrayList<>();
        for (int i = 0; i < num; i++) {
            HBaseRpcController pcrc = new HBaseRpcControllerImpl();
            BlockingRpcCallback<EchoResponseProto> done = new BlockingRpcCallback<>();
            stub.echo(pcrc, EchoRequestProto.newBuilder().setMessage("hello-" + i).build(), done);
            pcrcList.add(pcrc);
            callbackList.add(done);
        }
        for (int i = 0; i < num; i++) {
            HBaseRpcController pcrc = pcrcList.get(i);
            assertFalse(pcrc.failed());
            assertNull(pcrc.cellScanner());
            assertEquals("hello-" + i, callbackList.get(i).get().getMessage());
        }
    } finally {
        rpcServer.stop();
    }
}
Also used : Configuration(org.apache.hadoop.conf.Configuration) HBaseConfiguration(org.apache.hadoop.hbase.HBaseConfiguration) BlockingServiceAndInterface(org.apache.hadoop.hbase.ipc.RpcServer.BlockingServiceAndInterface) InetSocketAddress(java.net.InetSocketAddress) ArrayList(java.util.ArrayList) EchoResponseProto(org.apache.hadoop.hbase.shaded.ipc.protobuf.generated.TestProtos.EchoResponseProto) BlockingInterface(org.apache.hadoop.hbase.shaded.ipc.protobuf.generated.TestRpcServiceProtos.TestProtobufRpcProto.BlockingInterface) Interface(org.apache.hadoop.hbase.shaded.ipc.protobuf.generated.TestRpcServiceProtos.TestProtobufRpcProto.Interface) BlockingServiceAndInterface(org.apache.hadoop.hbase.ipc.RpcServer.BlockingServiceAndInterface) Test(org.junit.Test)

Example 2 with Interface

use of org.apache.hadoop.hbase.shaded.ipc.protobuf.generated.TestRpcServiceProtos.TestProtobufRpcProto.Interface in project hbase by apache.

the class AbstractTestIPC method testAsyncRemoteError.

@Test
public void testAsyncRemoteError() throws IOException {
    AbstractRpcClient<?> client = createRpcClient(CONF);
    RpcServer rpcServer = createRpcServer(null, "testRpcServer", Lists.newArrayList(new RpcServer.BlockingServiceAndInterface(SERVICE, null)), new InetSocketAddress("localhost", 0), CONF, new FifoRpcScheduler(CONF, 1));
    try {
        rpcServer.start();
        Interface stub = newStub(client, rpcServer.getListenerAddress());
        BlockingRpcCallback<EmptyResponseProto> callback = new BlockingRpcCallback<>();
        HBaseRpcController pcrc = new HBaseRpcControllerImpl();
        stub.error(pcrc, EmptyRequestProto.getDefaultInstance(), callback);
        assertNull(callback.get());
        assertTrue(pcrc.failed());
        LOG.info("Caught expected exception: " + pcrc.getFailed());
        IOException ioe = ProtobufUtil.handleRemoteException(pcrc.getFailed());
        assertTrue(ioe instanceof DoNotRetryIOException);
        assertTrue(ioe.getMessage().contains("server error!"));
    } finally {
        client.close();
        rpcServer.stop();
    }
}
Also used : BlockingServiceAndInterface(org.apache.hadoop.hbase.ipc.RpcServer.BlockingServiceAndInterface) DoNotRetryIOException(org.apache.hadoop.hbase.DoNotRetryIOException) InetSocketAddress(java.net.InetSocketAddress) EmptyResponseProto(org.apache.hadoop.hbase.shaded.ipc.protobuf.generated.TestProtos.EmptyResponseProto) DoNotRetryIOException(org.apache.hadoop.hbase.DoNotRetryIOException) IOException(java.io.IOException) BlockingInterface(org.apache.hadoop.hbase.shaded.ipc.protobuf.generated.TestRpcServiceProtos.TestProtobufRpcProto.BlockingInterface) Interface(org.apache.hadoop.hbase.shaded.ipc.protobuf.generated.TestRpcServiceProtos.TestProtobufRpcProto.Interface) BlockingServiceAndInterface(org.apache.hadoop.hbase.ipc.RpcServer.BlockingServiceAndInterface) Test(org.junit.Test)

Example 3 with Interface

use of org.apache.hadoop.hbase.shaded.ipc.protobuf.generated.TestRpcServiceProtos.TestProtobufRpcProto.Interface in project hbase by apache.

the class AbstractTestIPC method testAsyncTimeout.

@Test
public void testAsyncTimeout() throws IOException {
    RpcServer rpcServer = createRpcServer(null, "testRpcServer", Lists.newArrayList(new RpcServer.BlockingServiceAndInterface(SERVICE, null)), new InetSocketAddress("localhost", 0), CONF, new FifoRpcScheduler(CONF, 1));
    try (AbstractRpcClient<?> client = createRpcClient(CONF)) {
        rpcServer.start();
        Interface stub = newStub(client, rpcServer.getListenerAddress());
        List<HBaseRpcController> pcrcList = new ArrayList<>();
        List<BlockingRpcCallback<EmptyResponseProto>> callbackList = new ArrayList<>();
        int ms = 1000;
        int timeout = 100;
        long startTime = System.nanoTime();
        for (int i = 0; i < 10; i++) {
            HBaseRpcController pcrc = new HBaseRpcControllerImpl();
            pcrc.setCallTimeout(timeout);
            BlockingRpcCallback<EmptyResponseProto> callback = new BlockingRpcCallback<>();
            stub.pause(pcrc, PauseRequestProto.newBuilder().setMs(ms).build(), callback);
            pcrcList.add(pcrc);
            callbackList.add(callback);
        }
        for (BlockingRpcCallback<?> callback : callbackList) {
            assertNull(callback.get());
        }
        long waitTime = (System.nanoTime() - startTime) / 1000000;
        for (HBaseRpcController pcrc : pcrcList) {
            assertTrue(pcrc.failed());
            LOG.info("Caught expected exception: " + pcrc.getFailed());
            IOException ioe = ProtobufUtil.handleRemoteException(pcrc.getFailed());
            assertTrue(ioe.getCause() instanceof CallTimeoutException);
        }
        // confirm that we got exception before the actual pause.
        assertTrue(waitTime < ms);
    } finally {
        rpcServer.stop();
    }
}
Also used : BlockingServiceAndInterface(org.apache.hadoop.hbase.ipc.RpcServer.BlockingServiceAndInterface) InetSocketAddress(java.net.InetSocketAddress) ArrayList(java.util.ArrayList) EmptyResponseProto(org.apache.hadoop.hbase.shaded.ipc.protobuf.generated.TestProtos.EmptyResponseProto) DoNotRetryIOException(org.apache.hadoop.hbase.DoNotRetryIOException) IOException(java.io.IOException) BlockingInterface(org.apache.hadoop.hbase.shaded.ipc.protobuf.generated.TestRpcServiceProtos.TestProtobufRpcProto.BlockingInterface) Interface(org.apache.hadoop.hbase.shaded.ipc.protobuf.generated.TestRpcServiceProtos.TestProtobufRpcProto.Interface) BlockingServiceAndInterface(org.apache.hadoop.hbase.ipc.RpcServer.BlockingServiceAndInterface) Test(org.junit.Test)

Aggregations

InetSocketAddress (java.net.InetSocketAddress)3 BlockingServiceAndInterface (org.apache.hadoop.hbase.ipc.RpcServer.BlockingServiceAndInterface)3 BlockingInterface (org.apache.hadoop.hbase.shaded.ipc.protobuf.generated.TestRpcServiceProtos.TestProtobufRpcProto.BlockingInterface)3 Interface (org.apache.hadoop.hbase.shaded.ipc.protobuf.generated.TestRpcServiceProtos.TestProtobufRpcProto.Interface)3 Test (org.junit.Test)3 IOException (java.io.IOException)2 ArrayList (java.util.ArrayList)2 DoNotRetryIOException (org.apache.hadoop.hbase.DoNotRetryIOException)2 EmptyResponseProto (org.apache.hadoop.hbase.shaded.ipc.protobuf.generated.TestProtos.EmptyResponseProto)2 Configuration (org.apache.hadoop.conf.Configuration)1 HBaseConfiguration (org.apache.hadoop.hbase.HBaseConfiguration)1 EchoResponseProto (org.apache.hadoop.hbase.shaded.ipc.protobuf.generated.TestProtos.EchoResponseProto)1