blob: c2723e57d3b9497ca0d25e447ee774fe719d6de6 [file] [log] [blame]
Mark Slee57cc25e2007-02-28 21:43:54 +00001#!/usr/bin/env python
Mark Sleec9676562006-09-05 17:34:52 +00002
David Reissea2cba82009-03-30 21:35:00 +00003#
4# Licensed to the Apache Software Foundation (ASF) under one
5# or more contributor license agreements. See the NOTICE file
6# distributed with this work for additional information
7# regarding copyright ownership. The ASF licenses this file
8# to you under the Apache License, Version 2.0 (the
9# "License"); you may not use this file except in compliance
10# with the License. You may obtain a copy of the License at
11#
12# http://www.apache.org/licenses/LICENSE-2.0
13#
14# Unless required by applicable law or agreed to in writing,
15# software distributed under the License is distributed on an
16# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
17# KIND, either express or implied. See the License for the
18# specific language governing permissions and limitations
19# under the License.
20#
Jens Geyerd629ea02015-09-23 21:16:50 +020021import logging
22import os
James E. King III6f8c99e2018-03-24 16:32:02 -040023import signal
Jens Geyerd629ea02015-09-23 21:16:50 +020024import sys
25import time
Bryan Duxbury59d4efd2011-03-21 17:38:22 +000026from optparse import OptionParser
Mark Sleec9676562006-09-05 17:34:52 +000027
Nobuaki Sukegawa7af189a2016-02-11 16:21:01 +090028from util import local_libpath
James E. King III9804ab92019-02-07 16:59:05 -050029sys.path.insert(0, local_libpath())
30from thrift.protocol import TProtocol, TProtocolDecorator
Gregg Donovan62ec9292026-01-29 16:51:37 -050031from thrift.Thrift import TException
Nobuaki Sukegawa7af189a2016-02-11 16:21:01 +090032
Nobuaki Sukegawaa185d7e2015-11-06 21:24:24 +090033SCRIPT_DIR = os.path.abspath(os.path.dirname(__file__))
Roger Meierf4eec7a2011-09-11 18:16:21 +000034
Mark Sleec9676562006-09-05 17:34:52 +000035
Jens Geyerd629ea02015-09-23 21:16:50 +020036class TestHandler(object):
Carel Combrink5abe53f2025-11-13 06:16:41 +010037 def __init__(self, options):
38 self.options = options
39
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090040 def testVoid(self):
Carel Combrink5abe53f2025-11-13 06:16:41 +010041 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090042 logging.info('testVoid()')
Mark Sleec9676562006-09-05 17:34:52 +000043
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090044 def testString(self, str):
Carel Combrink5abe53f2025-11-13 06:16:41 +010045 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090046 logging.info('testString(%s)' % str)
47 return str
Mark Sleec9676562006-09-05 17:34:52 +000048
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090049 def testBool(self, boolean):
Carel Combrink5abe53f2025-11-13 06:16:41 +010050 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090051 logging.info('testBool(%s)' % str(boolean).lower())
52 return boolean
Nobuaki Sukegawaa649e742015-09-21 13:53:25 +090053
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090054 def testByte(self, byte):
Carel Combrink5abe53f2025-11-13 06:16:41 +010055 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090056 logging.info('testByte(%d)' % byte)
57 return byte
Mark Sleec9676562006-09-05 17:34:52 +000058
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090059 def testI16(self, i16):
Carel Combrink5abe53f2025-11-13 06:16:41 +010060 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090061 logging.info('testI16(%d)' % i16)
62 return i16
Mark Sleec98d0502006-09-06 02:42:25 +000063
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090064 def testI32(self, i32):
Carel Combrink5abe53f2025-11-13 06:16:41 +010065 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090066 logging.info('testI32(%d)' % i32)
67 return i32
Mark Sleec98d0502006-09-06 02:42:25 +000068
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090069 def testI64(self, i64):
Carel Combrink5abe53f2025-11-13 06:16:41 +010070 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090071 logging.info('testI64(%d)' % i64)
72 return i64
Mark Sleec98d0502006-09-06 02:42:25 +000073
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090074 def testDouble(self, dub):
Carel Combrink5abe53f2025-11-13 06:16:41 +010075 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090076 logging.info('testDouble(%f)' % dub)
77 return dub
Mark Sleec98d0502006-09-06 02:42:25 +000078
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090079 def testBinary(self, thing):
Carel Combrink5abe53f2025-11-13 06:16:41 +010080 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090081 logging.info('testBinary()') # TODO: hex output
82 return thing
Jens Geyerd629ea02015-09-23 21:16:50 +020083
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090084 def testStruct(self, thing):
Carel Combrink5abe53f2025-11-13 06:16:41 +010085 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090086 logging.info('testStruct({%s, %s, %s, %s})' % (thing.string_thing, thing.byte_thing, thing.i32_thing, thing.i64_thing))
87 return thing
Mark Sleec98d0502006-09-06 02:42:25 +000088
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090089 def testException(self, arg):
Carel Combrink5abe53f2025-11-13 06:16:41 +010090 from ThriftTest.ttypes import Xception
91 # if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090092 logging.info('testException(%s)' % arg)
93 if arg == 'Xception':
94 raise Xception(errorCode=1001, message=arg)
95 elif arg == 'TException':
96 raise TException(message='This is a TException')
Roger Meier1f554e12013-01-05 20:38:35 +010097
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090098 def testMultiException(self, arg0, arg1):
Carel Combrink5abe53f2025-11-13 06:16:41 +010099 from ThriftTest.ttypes import Xtruct, Xception, Xception2
100
101 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900102 logging.info('testMultiException(%s, %s)' % (arg0, arg1))
103 if arg0 == 'Xception':
104 raise Xception(errorCode=1001, message='This is an Xception')
105 elif arg0 == 'Xception2':
106 raise Xception2(
107 errorCode=2002,
108 struct_thing=Xtruct(string_thing='This is an Xception2'))
109 return Xtruct(string_thing=arg1)
Mark Sleec9676562006-09-05 17:34:52 +0000110
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900111 def testOneway(self, seconds):
Carel Combrink5abe53f2025-11-13 06:16:41 +0100112 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900113 logging.info('testOneway(%d) => sleeping...' % seconds)
114 time.sleep(seconds / 3) # be quick
Carel Combrink5abe53f2025-11-13 06:16:41 +0100115 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900116 logging.info('done sleeping')
David Reissdb893b62008-02-18 02:11:48 +0000117
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900118 def testNest(self, thing):
Carel Combrink5abe53f2025-11-13 06:16:41 +0100119 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900120 logging.info('testNest(%s)' % thing)
121 return thing
David Reiss74421272008-11-07 23:09:31 +0000122
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900123 def testMap(self, thing):
Carel Combrink5abe53f2025-11-13 06:16:41 +0100124 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900125 logging.info('testMap(%s)' % thing)
126 return thing
Jens Geyerd629ea02015-09-23 21:16:50 +0200127
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900128 def testStringMap(self, thing):
Carel Combrink5abe53f2025-11-13 06:16:41 +0100129 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900130 logging.info('testStringMap(%s)' % thing)
131 return thing
David Reiss74421272008-11-07 23:09:31 +0000132
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900133 def testSet(self, thing):
Carel Combrink5abe53f2025-11-13 06:16:41 +0100134 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900135 logging.info('testSet(%s)' % thing)
136 return thing
David Reiss74421272008-11-07 23:09:31 +0000137
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900138 def testList(self, thing):
Carel Combrink5abe53f2025-11-13 06:16:41 +0100139 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900140 logging.info('testList(%s)' % thing)
141 return thing
David Reiss74421272008-11-07 23:09:31 +0000142
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900143 def testEnum(self, thing):
Carel Combrink5abe53f2025-11-13 06:16:41 +0100144 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900145 logging.info('testEnum(%s)' % thing)
146 return thing
David Reiss74421272008-11-07 23:09:31 +0000147
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900148 def testTypedef(self, thing):
Carel Combrink5abe53f2025-11-13 06:16:41 +0100149 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900150 logging.info('testTypedef(%s)' % thing)
151 return thing
David Reiss74421272008-11-07 23:09:31 +0000152
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900153 def testMapMap(self, thing):
Carel Combrink5abe53f2025-11-13 06:16:41 +0100154 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900155 logging.info('testMapMap(%s)' % thing)
156 return {
157 -4: {
158 -4: -4,
159 -3: -3,
160 -2: -2,
161 -1: -1,
162 },
163 4: {
164 4: 4,
165 3: 3,
166 2: 2,
167 1: 1,
168 },
169 }
Roger Meier1f554e12013-01-05 20:38:35 +0100170
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900171 def testInsanity(self, argument):
Carel Combrink5abe53f2025-11-13 06:16:41 +0100172 from ThriftTest.ttypes import Insanity
173
174 if self.options.verbose > 1:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900175 logging.info('testInsanity(%s)' % argument)
176 return {
177 1: {
178 2: argument,
179 3: argument,
180 },
181 2: {6: Insanity()},
182 }
Bryan Duxbury59d4efd2011-03-21 17:38:22 +0000183
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900184 def testMulti(self, arg0, arg1, arg2, arg3, arg4, arg5):
Carel Combrink5abe53f2025-11-13 06:16:41 +0100185 from ThriftTest.ttypes import Xtruct
186
187 if self.options.verbose > 1:
Jens Geyer506e3112020-05-17 22:48:51 +0200188 logging.info('testMulti(%s, %s, %s, %s, %s, %s)' % (arg0, arg1, arg2, arg3, arg4, arg5))
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900189 return Xtruct(string_thing='Hello2',
190 byte_thing=arg0, i32_thing=arg1, i64_thing=arg2)
Roger Meier1f554e12013-01-05 20:38:35 +0100191
Bryan Duxbury59d4efd2011-03-21 17:38:22 +0000192
James E. King III9804ab92019-02-07 16:59:05 -0500193class SecondHandler(object):
194 def secondtestString(self, argument):
195 return "testString(\"" + argument + "\")"
196
197
198# LAST_SEQID is a global because we have one transport and multiple protocols
199# running on it (when multiplexed)
200LAST_SEQID = None
201
202
203class TPedanticSequenceIdProtocolWrapper(TProtocolDecorator.TProtocolDecorator):
204 """
205 Wraps any protocol with sequence ID checking: looks for outbound
206 uniqueness as well as request/response alignment.
207 """
208 def __init__(self, protocol):
209 # TProtocolDecorator.__new__ does all the heavy lifting
210 pass
211
212 def readMessageBegin(self):
213 global LAST_SEQID
214 (name, type, seqid) =\
215 super(TPedanticSequenceIdProtocolWrapper, self).readMessageBegin()
216 if LAST_SEQID is not None and LAST_SEQID == seqid:
217 raise TProtocol.TProtocolException(
218 TProtocol.TProtocolException.INVALID_DATA,
219 "We received the same seqid {0} twice in a row".format(seqid))
220 LAST_SEQID = seqid
221 return (name, type, seqid)
222
223
224def make_pedantic(proto):
225 """ Wrap a protocol in the pedantic sequence ID wrapper. """
226 # NOTE: this is disabled for now as many clients send seqid
227 # of zero and that is okay, need a way to identify
228 # clients that MUST send seqid unique to function right
229 # or just force all implementations to send unique seqids (preferred)
230 return proto # TPedanticSequenceIdProtocolWrapper(proto)
231
232
233class TPedanticSequenceIdProtocolFactory(TProtocol.TProtocolFactory):
234 def __init__(self, encapsulated):
235 super(TPedanticSequenceIdProtocolFactory, self).__init__()
236 self.encapsulated = encapsulated
237
238 def getProtocol(self, trans):
239 return make_pedantic(self.encapsulated.getProtocol(trans))
240
241
Nobuaki Sukegawaa185d7e2015-11-06 21:24:24 +0900242def main(options):
James E. King III9804ab92019-02-07 16:59:05 -0500243 # common header allowed client types
244 allowed_client_types = [
245 THeaderTransport.THeaderClientType.HEADERS,
246 THeaderTransport.THeaderClientType.FRAMED_BINARY,
247 THeaderTransport.THeaderClientType.UNFRAMED_BINARY,
248 THeaderTransport.THeaderClientType.FRAMED_COMPACT,
249 THeaderTransport.THeaderClientType.UNFRAMED_COMPACT,
250 ]
251
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900252 # set up the protocol factory form the --protocol option
253 prot_factories = {
Neil Williams66a44c52018-08-13 16:12:24 -0700254 'accel': TBinaryProtocol.TBinaryProtocolAcceleratedFactory(),
James E. King III9804ab92019-02-07 16:59:05 -0500255 'multia': TBinaryProtocol.TBinaryProtocolAcceleratedFactory(),
Neil Williams66a44c52018-08-13 16:12:24 -0700256 'accelc': TCompactProtocol.TCompactProtocolAcceleratedFactory(),
James E. King III9804ab92019-02-07 16:59:05 -0500257 'multiac': TCompactProtocol.TCompactProtocolAcceleratedFactory(),
258 'binary': TPedanticSequenceIdProtocolFactory(TBinaryProtocol.TBinaryProtocolFactory()),
259 'multi': TPedanticSequenceIdProtocolFactory(TBinaryProtocol.TBinaryProtocolFactory()),
Neil Williams66a44c52018-08-13 16:12:24 -0700260 'compact': TCompactProtocol.TCompactProtocolFactory(),
James E. King III9804ab92019-02-07 16:59:05 -0500261 'multic': TCompactProtocol.TCompactProtocolFactory(),
262 'header': THeaderProtocol.THeaderProtocolFactory(allowed_client_types),
263 'multih': THeaderProtocol.THeaderProtocolFactory(allowed_client_types),
Neil Williams66a44c52018-08-13 16:12:24 -0700264 'json': TJSONProtocol.TJSONProtocolFactory(),
James E. King III9804ab92019-02-07 16:59:05 -0500265 'multij': TJSONProtocol.TJSONProtocolFactory(),
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900266 }
Neil Williams66a44c52018-08-13 16:12:24 -0700267 pfactory = prot_factories.get(options.proto, None)
268 if pfactory is None:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900269 raise AssertionError('Unknown --protocol option: %s' % options.proto)
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900270 try:
271 pfactory.string_length_limit = options.string_limit
272 pfactory.container_length_limit = options.container_limit
James E. King, III350fe752017-10-25 09:57:18 -0400273 except Exception:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900274 # Ignore errors for those protocols that does not support length limit
275 pass
Bryan Duxbury16066592011-03-22 18:06:04 +0000276
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900277 # get the server type (TSimpleServer, TNonblockingServer, etc...)
278 if len(args) > 1:
279 raise AssertionError('Only one server type may be specified, not multiple types.')
280 server_type = args[0]
James E. King III6f8c99e2018-03-24 16:32:02 -0400281 if options.trans == 'http':
282 server_type = 'THttpServer'
David Reissbcaa2ad2008-06-10 22:55:26 +0000283
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900284 # Set up the handler and processor objects
Carel Combrink5abe53f2025-11-13 06:16:41 +0100285 handler = TestHandler(options)
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900286 processor = ThriftTest.Processor(handler)
Bryan Duxbury16066592011-03-22 18:06:04 +0000287
James E. King III9804ab92019-02-07 16:59:05 -0500288 if options.proto.startswith('multi'):
289 secondHandler = SecondHandler()
290 secondProcessor = SecondService.Processor(secondHandler)
291
292 multiplexedProcessor = TMultiplexedProcessor()
293 multiplexedProcessor.registerDefault(processor)
294 multiplexedProcessor.registerProcessor('ThriftTest', processor)
295 multiplexedProcessor.registerProcessor('SecondService', secondProcessor)
296 processor = multiplexedProcessor
297
James E. King III6f8c99e2018-03-24 16:32:02 -0400298 global server
299
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900300 # Handle THttpServer as a special case
301 if server_type == 'THttpServer':
James E. King III6f8c99e2018-03-24 16:32:02 -0400302 if options.ssl:
303 __certfile = os.path.join(os.path.dirname(SCRIPT_DIR), "keys", "server.crt")
304 __keyfile = os.path.join(os.path.dirname(SCRIPT_DIR), "keys", "server.key")
305 server = THttpServer.THttpServer(processor, ('', options.port), pfactory, cert_file=__certfile, key_file=__keyfile)
306 else:
307 server = THttpServer.THttpServer(processor, ('', options.port), pfactory)
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900308 server.serve()
309 sys.exit(0)
310
311 # set up server transport and transport factory
312
313 abs_key_path = os.path.join(os.path.dirname(SCRIPT_DIR), 'keys', 'server.pem')
314
315 host = None
316 if options.ssl:
317 from thrift.transport import TSSLSocket
318 transport = TSSLSocket.TSSLServerSocket(host, options.port, certfile=abs_key_path)
319 else:
Kengo Sekif1c53412019-12-13 08:09:36 +0900320 transport = TSocket.TServerSocket(host, options.port, options.domain_socket)
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900321 tfactory = TTransport.TBufferedTransportFactory()
322 if options.trans == 'buffered':
323 tfactory = TTransport.TBufferedTransportFactory()
324 elif options.trans == 'framed':
325 tfactory = TTransport.TFramedTransportFactory()
326 elif options.trans == '':
327 raise AssertionError('Unknown --transport option: %s' % options.trans)
328 else:
329 tfactory = TTransport.TBufferedTransportFactory()
330 # if --zlib, then wrap server transport, and use a different transport factory
331 if options.zlib:
Gregg Donovan62ec9292026-01-29 16:51:37 -0500332 if server_type != "TProcessPoolServer":
333 transport = TZlibTransport.TZlibTransport(transport) # wrap with zlib
334 # Avoid wrapping the server transport for process pools; TZlibTransport isn't picklable on spawn.
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900335 tfactory = TZlibTransport.TZlibTransportFactory()
336
337 # do server-specific setup here:
338 if server_type == "TNonblockingServer":
339 server = TNonblockingServer.TNonblockingServer(processor, transport, inputProtocolFactory=pfactory)
340 elif server_type == "TProcessPoolServer":
341 import signal
342 from thrift.server import TProcessPoolServer
343 server = TProcessPoolServer.TProcessPoolServer(processor, transport, tfactory, pfactory)
344 server.setNumWorkers(5)
345
346 def set_alarm():
347 def clean_shutdown(signum, frame):
348 for worker in server.workers:
349 if options.verbose > 0:
350 logging.info('Terminating worker: %s' % worker)
351 worker.terminate()
352 if options.verbose > 0:
353 logging.info('Requesting server to stop()')
354 try:
355 server.stop()
James E. King, III350fe752017-10-25 09:57:18 -0400356 except Exception:
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900357 pass
358 signal.signal(signal.SIGALRM, clean_shutdown)
359 signal.alarm(4)
360 set_alarm()
361 else:
362 # look up server class dynamically to instantiate server
363 ServerClass = getattr(TServer, server_type)
364 server = ServerClass(processor, transport, tfactory, pfactory)
365 # enter server main loop
Nobuaki Sukegawaa185d7e2015-11-06 21:24:24 +0900366 server.serve()
Nobuaki Sukegawaa185d7e2015-11-06 21:24:24 +0900367
James E. King, III0ad20bd2017-09-30 15:44:16 -0700368
James E. King III6f8c99e2018-03-24 16:32:02 -0400369def exit_gracefully(signum, frame):
370 print("SIGINT received\n")
371 server.shutdown() # doesn't work properly, yet
372 sys.exit(0)
373
374
Nobuaki Sukegawaa185d7e2015-11-06 21:24:24 +0900375if __name__ == '__main__':
James E. King III6f8c99e2018-03-24 16:32:02 -0400376 signal.signal(signal.SIGINT, exit_gracefully)
377
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900378 parser = OptionParser()
379 parser.add_option('--libpydir', type='string', dest='libpydir',
380 help='include this directory to sys.path for locating library code')
381 parser.add_option('--genpydir', type='string', dest='genpydir',
382 default='gen-py',
383 help='include this directory to sys.path for locating generated code')
384 parser.add_option("--port", type="int", dest="port",
385 help="port number for server to listen on")
386 parser.add_option("--zlib", action="store_true", dest="zlib",
387 help="use zlib wrapper for compressed transport")
388 parser.add_option("--ssl", action="store_true", dest="ssl",
389 help="use SSL for encrypted transport")
390 parser.add_option('-v', '--verbose', action="store_const",
391 dest="verbose", const=2,
392 help="verbose output")
393 parser.add_option('-q', '--quiet', action="store_const",
394 dest="verbose", const=0,
395 help="minimal output")
396 parser.add_option('--protocol', dest="proto", type="string",
James E. King III9804ab92019-02-07 16:59:05 -0500397 help="protocol to use, one of: accel, accelc, binary, compact, json, multi, multia, multiac, multic, multih, multij")
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900398 parser.add_option('--transport', dest="trans", type="string",
James E. King III6f8c99e2018-03-24 16:32:02 -0400399 help="transport to use, one of: buffered, framed, http")
Kengo Sekif1c53412019-12-13 08:09:36 +0900400 parser.add_option('--domain-socket', dest="domain_socket", type="string",
401 help="Unix domain socket path")
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900402 parser.add_option('--container-limit', dest='container_limit', type='int', default=None)
403 parser.add_option('--string-limit', dest='string_limit', type='int', default=None)
James E. King III6f8c99e2018-03-24 16:32:02 -0400404 parser.set_defaults(port=9090, verbose=1, proto='binary', transport='buffered')
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900405 options, args = parser.parse_args()
Nobuaki Sukegawaa185d7e2015-11-06 21:24:24 +0900406
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900407 # Print TServer log to stdout so that the test-runner can redirect it to log files
408 logging.basicConfig(level=options.verbose)
Nobuaki Sukegawa7b545b52016-01-11 13:46:04 +0900409
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900410 sys.path.insert(0, os.path.join(SCRIPT_DIR, options.genpydir))
Nobuaki Sukegawaa185d7e2015-11-06 21:24:24 +0900411
James E. King III9804ab92019-02-07 16:59:05 -0500412 from ThriftTest import ThriftTest, SecondService
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900413 from thrift.Thrift import TException
James E. King III9804ab92019-02-07 16:59:05 -0500414 from thrift.TMultiplexedProcessor import TMultiplexedProcessor
Neil Williams66a44c52018-08-13 16:12:24 -0700415 from thrift.transport import THeaderTransport
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900416 from thrift.transport import TTransport
417 from thrift.transport import TSocket
418 from thrift.transport import TZlibTransport
419 from thrift.protocol import TBinaryProtocol
420 from thrift.protocol import TCompactProtocol
Neil Williams66a44c52018-08-13 16:12:24 -0700421 from thrift.protocol import THeaderProtocol
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900422 from thrift.protocol import TJSONProtocol
423 from thrift.server import TServer, TNonblockingServer, THttpServer
Nobuaki Sukegawaa185d7e2015-11-06 21:24:24 +0900424
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900425 sys.exit(main(options))