use of org.nustaq.kontraktor.remoting.http.undertow.WebSocketPublisher in project kontraktor by RuedigerMoeller.
the class RemotingTest method runWS.
public void runWS(Coding coding) throws InterruptedException {
checkSequenceErrors = true;
RemotingTestService service = Actors.AsActor(RemotingTestService.class, Q_SIZE);
ActorServer publisher = new WebSocketPublisher(service, "localhost", "/ws", 8081).coding(coding).publish().await();
RemotingTestService client = (RemotingTestService) new WebSocketConnectable(RemotingTestService.class, "ws://localhost:8081/ws").coding(coding).connect().await(9999999);
CountDownLatch latch = new CountDownLatch(1);
runWithClient(client, latch);
latch.await();
// wait for outstanding callbacks
Thread.sleep(2000);
publisher.close();
}
use of org.nustaq.kontraktor.remoting.http.undertow.WebSocketPublisher in project kontraktor by RuedigerMoeller.
the class BldFourK method websocket.
public WebSocketPublisher websocket(String urlPath, Actor facade, boolean useStringMessages) {
WebSocketPublisher wp = new WebSocketPublisher(this, facade, hostName, urlPath, port);
wp.sendStringMessages(useStringMessages);
items.add(wp);
return wp;
}
use of org.nustaq.kontraktor.remoting.http.undertow.WebSocketPublisher in project kontraktor by RuedigerMoeller.
the class BldFourK method build.
public BldFourK build() {
Http4K http4K = Http4K.get();
// fixme https
http4K.getServer(getPort(), getHostName(), context);
getItems().forEach(item -> {
if (item instanceof HttpPublisher) {
http4K.publish((HttpPublisher) item);
} else if (item instanceof WebSocketPublisher) {
http4K.publish((WebSocketPublisher) item);
} else if (item instanceof BldDirRoot) {
BldDirRoot dr = (BldDirRoot) item;
if (getHttpCacheEnabled()) {
CachedFileResourceManager resMan = new CachedFileResourceManager(getHttpCacheEnabled(), new File(dr.getDir()), 100);
http4K.publishFileSystem(getHostName(), dr.getUrlPath(), getPort(), resMan);
} else {
http4K.publishFileSystem(getHostName(), dr.getUrlPath(), getPort(), new File(dr.getDir()));
}
} else if (item instanceof BldHttpHandler) {
BldHttpHandler dr = (BldHttpHandler) item;
http4K.publishHandler(getHostName(), dr.getUrlPath(), getPort(), dr.getHandler());
} else if (item instanceof BldResPath) {
BldResPath dr = (BldResPath) item;
DynamicResourceManager drm = new DynamicResourceManager(!dr.isCacheAggregates(), dr.getUrlPath(), dr.isMinify(), dr.getBaseDir(), dr.getResourcePath());
drm.cachedIndexDir(dr.getProductionBuildDir());
HtmlImportShim shim = new HtmlImportShim(dr.getUrlPath());
drm.setJSPostProcessors(dr.getProdModePostProcessors());
shim.setJSPostProcessors(dr.getProdModePostProcessors());
shim.minify(dr.isMinify()).inline(dr.isInline()).stripComments(dr.isStripComments());
drm.setImportShim(shim);
drm.setTranspilerMap(dr.getTranspilers());
http4K.publishResourcePath(getHostName(), dr.getUrlPath(), getPort(), drm, dr.isCompress(), dr.getHandlerInterceptor());
} else {
System.out.println("unexpected item " + item);
}
});
return this;
}
use of org.nustaq.kontraktor.remoting.http.undertow.WebSocketPublisher in project kontraktor by RuedigerMoeller.
the class RemotingTest method testWSMany.
@Test
public void testWSMany() throws Exception {
checkSequenceErrors = false;
RemotingTestService service = Actors.AsActor(RemotingTestService.class, Q_SIZE);
ActorServer publisher = new WebSocketPublisher(service, "localhost", "/ws", 8081).publish().await();
RemotingTestService client = (RemotingTestService) new WebSocketConnectable(RemotingTestService.class, "ws://localhost:8081/ws").connect().await(9999999);
ExecutorService exec = Executors.newCachedThreadPool();
CountDownLatch latch = new CountDownLatch(10);
for (int i = 0; i < 10; i++) {
exec.execute(() -> {
try {
runWithClient(client, latch);
} catch (Exception e) {
e.printStackTrace();
}
});
}
latch.await();
// wait for outstanding callbacks
Thread.sleep(2000);
publisher.close();
}
use of org.nustaq.kontraktor.remoting.http.undertow.WebSocketPublisher in project kontraktor by RuedigerMoeller.
the class RemotingTest method test.
@Test
public void test() {
RemotingTA serv = Actors.AsActor(RemotingTA.class);
// websocket
WebSocketPublisher pub = new WebSocketPublisher().facade(serv).hostName("0.0.0.0").urlPath("/websocket").port(7777).serType(SerializerType.FSTSer);
pub.publish().await();
WebSocketConnectable con = new WebSocketConnectable().actorClass(RemotingTA.class).url("ws://localhost:7777/websocket");
fromRemote(con);
// TCP NIO
new TCPNIOPublisher(serv, 7778).publish().await();
fromRemote(new TCPConnectable(RemotingTA.class, "localhost", 7778));
// TCP Sync
new TCPPublisher(serv, 7780).publish().await();
fromRemote(new TCPConnectable(RemotingTA.class, "localhost", 7780));
// Http-Longpoll
new HttpPublisher(serv, "0.0.0.0", "/httpapi", 7779).publish().await();
fromRemote(new HttpConnectable(RemotingTA.class, "http://localhost:7779/httpapi"));
}
Aggregations