| /* | 
 |  * Licensed to the Apache Software Foundation (ASF) under one | 
 |  * or more contributor license agreements. See the NOTICE file | 
 |  * distributed with this work for additional information | 
 |  * regarding copyright ownership. The ASF licenses this file | 
 |  * to you under the Apache License, Version 2.0 (the | 
 |  * "License"); you may not use this file except in compliance | 
 |  * with the License. You may obtain a copy of the License at | 
 |  * | 
 |  *   http://www.apache.org/licenses/LICENSE-2.0 | 
 |  * | 
 |  * Unless required by applicable law or agreed to in writing, | 
 |  * software distributed under the License is distributed on an | 
 |  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | 
 |  * KIND, either express or implied. See the License for the | 
 |  * specific language governing permissions and limitations | 
 |  * under the License. | 
 |  */ | 
 | module stress_test_server; | 
 |  | 
 | import std.getopt; | 
 | import std.parallelism : totalCPUs; | 
 | import std.stdio; | 
 | import std.typetuple; | 
 | import thrift.codegen.processor; | 
 | import thrift.protocol.binary; | 
 | import thrift.server.base; | 
 | import thrift.server.transport.socket; | 
 | import thrift.transport.buffered; | 
 | import thrift.transport.memory; | 
 | import thrift.transport.socket; | 
 | import thrift.util.hashset; | 
 | import test_utils; | 
 |  | 
 | import thrift.test.stress.Service; | 
 |  | 
 | class ServiceHandler : Service { | 
 |   void echoVoid() { return; } | 
 |   byte echoByte(byte arg) { return arg; } | 
 |   int echoI32(int arg) { return arg; } | 
 |   long echoI64(long arg) { return arg; } | 
 |   byte[] echoList(byte[] arg) { return arg; } | 
 |   HashSet!byte echoSet(HashSet!byte arg) { return arg; } | 
 |   byte[byte] echoMap(byte[byte] arg) { return arg; } | 
 |  | 
 |   string echoString(string arg) { | 
 |     if (arg != "hello") { | 
 |       stderr.writefln(`Wrong string received: %s instead of "hello"`, arg); | 
 |       throw new Exception("Wrong string received."); | 
 |     } | 
 |     return arg; | 
 |   } | 
 | } | 
 |  | 
 | void main(string[] args) { | 
 |   ushort port = 9091; | 
 |   auto serverType = ServerType.threaded; | 
 |   TransportType transportType; | 
 |   size_t numIOThreads = 1; | 
 |   size_t taskPoolSize = totalCPUs; | 
 |  | 
 |   getopt(args, "port", &port, "server-type", &serverType, | 
 |     "transport-type", &transportType, "task-pool-size", &taskPoolSize, | 
 |     "num-io-threads", &numIOThreads); | 
 |  | 
 |   alias TypeTuple!(TBufferedTransport, TMemoryBuffer) AvailableTransports; | 
 |  | 
 |   auto processor = new TServiceProcessor!(Service, | 
 |     staticMap!(TBinaryProtocol, AvailableTransports))(new ServiceHandler()); | 
 |   auto serverSocket = new TServerSocket(port); | 
 |   auto transportFactory = createTransportFactory(transportType); | 
 |   auto protocolFactory = new TBinaryProtocolFactory!AvailableTransports; | 
 |  | 
 |   auto server = createServer(serverType, taskPoolSize, numIOThreads, | 
 |     processor, serverSocket, transportFactory, protocolFactory); | 
 |  | 
 |   writefln("Starting %s %s StressTest server on port %s...", transportType, | 
 |     serverType, port); | 
 |   server.serve(); | 
 |   writeln("done."); | 
 | } |