Search in sources :

Example 6 with DemoServiceImpl

use of com.alibaba.dubbo.rpc.protocol.dubbo.support.DemoServiceImpl in project dubbo by alibaba.

the class DubboProtocolTest method testDubboProtocolMultiService.

@Test
public void testDubboProtocolMultiService() throws Exception {
    DemoService service = new DemoServiceImpl();
    protocol.export(proxy.getInvoker(service, DemoService.class, URL.valueOf("dubbo://127.0.0.1:9010/" + DemoService.class.getName())));
    service = proxy.getProxy(protocol.refer(DemoService.class, URL.valueOf("dubbo://127.0.0.1:9010/" + DemoService.class.getName())));
    RemoteService remote = new RemoteServiceImpl();
    protocol.export(proxy.getInvoker(remote, RemoteService.class, URL.valueOf("dubbo://127.0.0.1:9010/" + RemoteService.class.getName())));
    remote = proxy.getProxy(protocol.refer(RemoteService.class, URL.valueOf("dubbo://127.0.0.1:9010/" + RemoteService.class.getName())));
    service.sayHello("world");
    // test netty client
    assertEquals("world", service.echo("world"));
    assertEquals("hello world@" + RemoteServiceImpl.class.getName(), remote.sayHello("world"));
    EchoService serviceEcho = (EchoService) service;
    assertEquals(serviceEcho.$echo("test"), "test");
    EchoService remoteEecho = (EchoService) remote;
    assertEquals(remoteEecho.$echo("ok"), "ok");
}
Also used : RemoteService(com.alibaba.dubbo.rpc.protocol.dubbo.support.RemoteService) EchoService(com.alibaba.dubbo.rpc.service.EchoService) DemoService(com.alibaba.dubbo.rpc.protocol.dubbo.support.DemoService) RemoteServiceImpl(com.alibaba.dubbo.rpc.protocol.dubbo.support.RemoteServiceImpl) DemoServiceImpl(com.alibaba.dubbo.rpc.protocol.dubbo.support.DemoServiceImpl) Test(org.junit.Test)

Example 7 with DemoServiceImpl

use of com.alibaba.dubbo.rpc.protocol.dubbo.support.DemoServiceImpl in project dubbo by alibaba.

the class DubboProtocolTest method testPerm.

@Test
public void testPerm() throws Exception {
    DemoService service = new DemoServiceImpl();
    protocol.export(proxy.getInvoker(service, DemoService.class, URL.valueOf("dubbo://127.0.0.1:9050/" + DemoService.class.getName() + "?codec=exchange")));
    service = proxy.getProxy(protocol.refer(DemoService.class, URL.valueOf("dubbo://127.0.0.1:9050/" + DemoService.class.getName() + "?codec=exchange")));
    long start = System.currentTimeMillis();
    for (int i = 0; i < 1000; i++) service.getSize(new String[] { "", "", "" });
    System.out.println("take:" + (System.currentTimeMillis() - start));
}
Also used : DemoService(com.alibaba.dubbo.rpc.protocol.dubbo.support.DemoService) DemoServiceImpl(com.alibaba.dubbo.rpc.protocol.dubbo.support.DemoServiceImpl) Test(org.junit.Test)

Example 8 with DemoServiceImpl

use of com.alibaba.dubbo.rpc.protocol.dubbo.support.DemoServiceImpl in project dubbo by alibaba.

the class MultiThreadTest method testDubboMultiThreadInvoke.

public void testDubboMultiThreadInvoke() throws Exception {
    Exporter<?> rpcExporter = protocol.export(proxy.getInvoker(new DemoServiceImpl(), DemoService.class, URL.valueOf("dubbo://127.0.0.1:20259/TestService")));
    final AtomicInteger counter = new AtomicInteger();
    final DemoService service = proxy.getProxy(protocol.refer(DemoService.class, URL.valueOf("dubbo://127.0.0.1:20259/TestService")));
    assertEquals(service.getSize(new String[] { "123", "456", "789" }), 3);
    final StringBuffer sb = new StringBuffer();
    for (int i = 0; i < 1024 * 64 + 32; i++) sb.append('A');
    assertEquals(sb.toString(), service.echo(sb.toString()));
    ExecutorService exec = Executors.newFixedThreadPool(10);
    for (int i = 0; i < 10; i++) {
        final int fi = i;
        exec.execute(new Runnable() {

            public void run() {
                for (int i = 0; i < 30; i++) {
                    System.out.println(fi + ":" + counter.getAndIncrement());
                    assertEquals(service.echo(sb.toString()), sb.toString());
                }
            }
        });
    }
    exec.shutdown();
    exec.awaitTermination(10, TimeUnit.SECONDS);
    rpcExporter.unexport();
}
Also used : AtomicInteger(java.util.concurrent.atomic.AtomicInteger) ExecutorService(java.util.concurrent.ExecutorService) DemoService(com.alibaba.dubbo.rpc.protocol.dubbo.support.DemoService) DemoServiceImpl(com.alibaba.dubbo.rpc.protocol.dubbo.support.DemoServiceImpl)

Example 9 with DemoServiceImpl

use of com.alibaba.dubbo.rpc.protocol.dubbo.support.DemoServiceImpl in project dubbo by alibaba.

the class RpcFilterTest method testRpcFilter.

public void testRpcFilter() throws Exception {
    DemoService service = new DemoServiceImpl();
    URL url = URL.valueOf("dubbo://127.0.0.1:9010/com.alibaba.dubbo.rpc.DemoService?service.filter=echo");
    protocol.export(proxy.getInvoker(service, DemoService.class, url));
    service = proxy.getProxy(protocol.refer(DemoService.class, url));
    assertEquals("123", service.echo("123"));
    // cast to EchoService
    EchoService echo = proxy.getProxy(protocol.refer(EchoService.class, url));
    assertEquals(echo.$echo("test"), "test");
    assertEquals(echo.$echo("abcdefg"), "abcdefg");
    assertEquals(echo.$echo(1234), 1234);
}
Also used : EchoService(com.alibaba.dubbo.rpc.service.EchoService) DemoService(com.alibaba.dubbo.rpc.protocol.dubbo.support.DemoService) URL(com.alibaba.dubbo.common.URL) DemoServiceImpl(com.alibaba.dubbo.rpc.protocol.dubbo.support.DemoServiceImpl)

Aggregations

DemoService (com.alibaba.dubbo.rpc.protocol.dubbo.support.DemoService)9 DemoServiceImpl (com.alibaba.dubbo.rpc.protocol.dubbo.support.DemoServiceImpl)9 Test (org.junit.Test)7 EchoService (com.alibaba.dubbo.rpc.service.EchoService)4 RpcException (com.alibaba.dubbo.rpc.RpcException)2 Type (com.alibaba.dubbo.rpc.protocol.dubbo.support.Type)2 HashMap (java.util.HashMap)2 URL (com.alibaba.dubbo.common.URL)1 NonSerialized (com.alibaba.dubbo.rpc.protocol.dubbo.support.NonSerialized)1 RemoteService (com.alibaba.dubbo.rpc.protocol.dubbo.support.RemoteService)1 RemoteServiceImpl (com.alibaba.dubbo.rpc.protocol.dubbo.support.RemoteServiceImpl)1 ExecutorService (java.util.concurrent.ExecutorService)1 AtomicInteger (java.util.concurrent.atomic.AtomicInteger)1