blob: eecb8500a9fbca16b9c2d3e4f877e75b376992d6 [file] [log] [blame]
Mark Slee57cc25e2007-02-28 21:43:54 +00001#!/usr/bin/env python
Mark Sleefc89d392006-09-04 00:04:39 +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#
21
Mark Slee5299a952007-10-05 00:13:24 +000022import sys, glob
23sys.path.insert(0, './gen-py')
24sys.path.insert(0, glob.glob('../../lib/py/build/lib.*')[0])
Mark Sleefc89d392006-09-04 00:04:39 +000025
Mark Slee57cc25e2007-02-28 21:43:54 +000026from ThriftTest import ThriftTest
27from ThriftTest.ttypes import *
Mark Sleec9676562006-09-05 17:34:52 +000028from thrift.transport import TTransport
Mark Sleefc89d392006-09-04 00:04:39 +000029from thrift.transport import TSocket
David Reissf78ec2b2009-01-31 21:59:32 +000030from thrift.transport import THttpClient
Mark Sleefc89d392006-09-04 00:04:39 +000031from thrift.protocol import TBinaryProtocol
Bryan Duxbury59d4efd2011-03-21 17:38:22 +000032from thrift.protocol import TCompactProtocol
Mark Slee5299a952007-10-05 00:13:24 +000033import unittest
Mark Slee57cc25e2007-02-28 21:43:54 +000034import time
Mark Slee5299a952007-10-05 00:13:24 +000035from optparse import OptionParser
Mark Slee57cc25e2007-02-28 21:43:54 +000036
Mark Sleea3302652006-10-25 19:03:32 +000037
Mark Slee5299a952007-10-05 00:13:24 +000038parser = OptionParser()
David Reiss74421272008-11-07 23:09:31 +000039parser.add_option("--port", type="int", dest="port",
40 help="connect to server at port")
41parser.add_option("--host", type="string", dest="host",
42 help="connect to server")
43parser.add_option("--framed", action="store_true", dest="framed",
44 help="use framed transport")
David Reissf78ec2b2009-01-31 21:59:32 +000045parser.add_option("--http", dest="http_path",
46 help="Use the HTTP transport with the specified path")
David Reiss74421272008-11-07 23:09:31 +000047parser.add_option('-v', '--verbose', action="store_const",
48 dest="verbose", const=2,
49 help="verbose output")
50parser.add_option('-q', '--quiet', action="store_const",
51 dest="verbose", const=0,
52 help="minimal output")
Bryan Duxbury59d4efd2011-03-21 17:38:22 +000053parser.add_option('--proto', dest="proto", type="string",
54 help="protocol to use, one of: accel, binary, compact")
55parser.set_defaults(framed=False, http_path=None, verbose=1, host='localhost', port=9090, proto='binary')
David Reiss74421272008-11-07 23:09:31 +000056options, args = parser.parse_args()
Mark Sleea3302652006-10-25 19:03:32 +000057
Mark Slee5299a952007-10-05 00:13:24 +000058class AbstractTest(unittest.TestCase):
Mark Slee5299a952007-10-05 00:13:24 +000059 def setUp(self):
David Reissf78ec2b2009-01-31 21:59:32 +000060 if options.http_path:
61 self.transport = THttpClient.THttpClient(
62 options.host, options.port, options.http_path)
Mark Slee5299a952007-10-05 00:13:24 +000063 else:
David Reissf78ec2b2009-01-31 21:59:32 +000064 socket = TSocket.TSocket(options.host, options.port)
65
66 # frame or buffer depending upon args
67 if options.framed:
68 self.transport = TTransport.TFramedTransport(socket)
69 else:
70 self.transport = TTransport.TBufferedTransport(socket)
Mark Sleefc89d392006-09-04 00:04:39 +000071
Mark Slee5299a952007-10-05 00:13:24 +000072 self.transport.open()
David Reiss0c90f6f2008-02-06 22:18:40 +000073
Mark Slee5299a952007-10-05 00:13:24 +000074 protocol = self.protocol_factory.getProtocol(self.transport)
75 self.client = ThriftTest.Client(protocol)
David Reiss0c90f6f2008-02-06 22:18:40 +000076
Mark Slee5299a952007-10-05 00:13:24 +000077 def tearDown(self):
78 # Close!
79 self.transport.close()
Mark Sleefc89d392006-09-04 00:04:39 +000080
Mark Slee5299a952007-10-05 00:13:24 +000081 def testVoid(self):
82 self.client.testVoid()
David Reiss0c90f6f2008-02-06 22:18:40 +000083
Mark Slee5299a952007-10-05 00:13:24 +000084 def testString(self):
85 self.assertEqual(self.client.testString('Python'), 'Python')
Bryan Duxbury59d4efd2011-03-21 17:38:22 +000086 self.assertEqual(self.client.testString(''), '')
Mark Sleec9676562006-09-05 17:34:52 +000087
Mark Slee5299a952007-10-05 00:13:24 +000088 def testByte(self):
89 self.assertEqual(self.client.testByte(63), 63)
Bryan Duxbury59d4efd2011-03-21 17:38:22 +000090 self.assertEqual(self.client.testByte(-127), -127)
Mark Sleec98d0502006-09-06 02:42:25 +000091
Mark Slee5299a952007-10-05 00:13:24 +000092 def testI32(self):
93 self.assertEqual(self.client.testI32(-1), -1)
94 self.assertEqual(self.client.testI32(0), 0)
Mark Sleec9676562006-09-05 17:34:52 +000095
Mark Slee5299a952007-10-05 00:13:24 +000096 def testI64(self):
Bryan Duxbury59d4efd2011-03-21 17:38:22 +000097 self.assertEqual(self.client.testI64(1), 1)
Mark Slee5299a952007-10-05 00:13:24 +000098 self.assertEqual(self.client.testI64(-34359738368), -34359738368)
Mark Sleec98d0502006-09-06 02:42:25 +000099
Mark Slee5299a952007-10-05 00:13:24 +0000100 def testDouble(self):
101 self.assertEqual(self.client.testDouble(-5.235098235), -5.235098235)
Bryan Duxbury59d4efd2011-03-21 17:38:22 +0000102 self.assertEqual(self.client.testDouble(0), 0)
103 self.assertEqual(self.client.testDouble(-1), -1)
Mark Sleec9676562006-09-05 17:34:52 +0000104
Mark Slee5299a952007-10-05 00:13:24 +0000105 def testStruct(self):
106 x = Xtruct()
107 x.string_thing = "Zero"
108 x.byte_thing = 1
109 x.i32_thing = -3
110 x.i64_thing = -5
111 y = self.client.testStruct(x)
Bryan Duxbury59d4efd2011-03-21 17:38:22 +0000112 self.assertEqual(y, x)
Mark Sleefc89d392006-09-04 00:04:39 +0000113
Bryan Duxbury59d4efd2011-03-21 17:38:22 +0000114 def testNest(self):
115 inner = Xtruct(string_thing="Zero", byte_thing=1, i32_thing=-3,
116 i64_thing=-5)
117 x = Xtruct2(struct_thing=inner)
118 y = self.client.testNest(x)
119 self.assertEqual(y, x)
120
121 def testMap(self):
122 x = {0:1, 1:2, 2:3, 3:4, -1:-2}
123 y = self.client.testMap(x)
124 self.assertEqual(y, x)
125
126 def testSet(self):
127 x = set([8, 1, 42])
128 y = self.client.testSet(x)
129 self.assertEqual(y, x)
130
131 def testList(self):
132 x = [1, 4, 9, -42]
133 y = self.client.testList(x)
134 self.assertEqual(y, x)
135
136 def testEnum(self):
137 x = Numberz.FIVE
138 y = self.client.testEnum(x)
139 self.assertEqual(y, x)
140
141 def testTypedef(self):
142 x = 0xffffffffffffff # 7 bytes of 0xff
143 y = self.client.testTypedef(x)
144 self.assertEqual(y, x)
145
146 def testMapMap(self):
147 # does not work: dict() is not a hashable type, so a dict() cannot be used as a key in another dict()
148 #x = { {1:10, 2:20}, {1:100, 2:200, 3:300}, {1:1000, 2:2000, 3:3000, 4:4000} }
149 try:
150 y = self.client.testMapMap()
151 except:
152 pass
153
154 def testMulti(self):
155 xpected = Xtruct(byte_thing=74, i32_thing=0xff00ff, i64_thing=0xffffffffd0d0)
156 y = self.client.testMulti(xpected.byte_thing,
157 xpected.i32_thing,
158 xpected.i64_thing,
159 { 0:'abc' },
160 Numberz.FIVE,
161 0xf0f0f0)
162 self.assertEqual(y, xpected)
Mark Sleec9676562006-09-05 17:34:52 +0000163
Mark Slee5299a952007-10-05 00:13:24 +0000164 def testException(self):
165 self.client.testException('Safe')
166 try:
167 self.client.testException('Xception')
168 self.fail("should have gotten exception")
169 except Xception, x:
170 self.assertEqual(x.errorCode, 1001)
171 self.assertEqual(x.message, 'Xception')
Mark Sleec9676562006-09-05 17:34:52 +0000172
David Reissbcaa2ad2008-06-10 22:55:26 +0000173 try:
174 self.client.testException("throw_undeclared")
175 self.fail("should have thrown exception")
176 except Exception: # type is undefined
177 pass
178
David Reiss6ce401d2009-03-24 20:01:58 +0000179 def testOneway(self):
David Reissdb893b62008-02-18 02:11:48 +0000180 start = time.time()
Bryan Duxbury59d4efd2011-03-21 17:38:22 +0000181 self.client.testOneway(1) # type is int, not float
David Reissdb893b62008-02-18 02:11:48 +0000182 end = time.time()
Bryan Duxbury59d4efd2011-03-21 17:38:22 +0000183 self.assertTrue(end - start < 3,
David Reiss6ce401d2009-03-24 20:01:58 +0000184 "oneway sleep took %f sec" % (end - start))
Todd Lipconf5dea4c2009-12-03 01:18:44 +0000185
186 def testOnewayThenNormal(self):
Bryan Duxbury59d4efd2011-03-21 17:38:22 +0000187 self.client.testOneway(1) # type is int, not float
Todd Lipconf5dea4c2009-12-03 01:18:44 +0000188 self.assertEqual(self.client.testString('Python'), 'Python')
David Reissdb893b62008-02-18 02:11:48 +0000189
Mark Slee5299a952007-10-05 00:13:24 +0000190class NormalBinaryTest(AbstractTest):
191 protocol_factory = TBinaryProtocol.TBinaryProtocolFactory()
Mark Sleefc89d392006-09-04 00:04:39 +0000192
Bryan Duxbury59d4efd2011-03-21 17:38:22 +0000193class CompactTest(AbstractTest):
194 protocol_factory = TCompactProtocol.TCompactProtocolFactory()
195
Mark Slee5299a952007-10-05 00:13:24 +0000196class AcceleratedBinaryTest(AbstractTest):
197 protocol_factory = TBinaryProtocol.TBinaryProtocolAcceleratedFactory()
Mark Sleea3302652006-10-25 19:03:32 +0000198
David Reiss9ff3b9d2008-02-15 01:10:23 +0000199def suite():
200 suite = unittest.TestSuite()
201 loader = unittest.TestLoader()
Bryan Duxbury59d4efd2011-03-21 17:38:22 +0000202 if options.proto == 'binary': # look for --proto on cmdline
203 suite.addTest(loader.loadTestsFromTestCase(NormalBinaryTest))
204 elif options.proto == 'accel':
205 suite.addTest(loader.loadTestsFromTestCase(AcceleratedBinaryTest))
206 elif options.proto == 'compact':
207 suite.addTest(loader.loadTestsFromTestCase(CompactTest))
208 else:
209 raise AssertionError('Unknown protocol given with --proto: %s' % options.proto)
David Reiss9ff3b9d2008-02-15 01:10:23 +0000210 return suite
Mark Slee5299a952007-10-05 00:13:24 +0000211
David Reiss74421272008-11-07 23:09:31 +0000212class OwnArgsTestProgram(unittest.TestProgram):
213 def parseArgs(self, argv):
214 if args:
215 self.testNames = args
216 else:
217 self.testNames = (self.defaultTest,)
218 self.createTests()
219
David Reiss9ff3b9d2008-02-15 01:10:23 +0000220if __name__ == "__main__":
David Reiss74421272008-11-07 23:09:31 +0000221 OwnArgsTestProgram(defaultTest="suite", testRunner=unittest.TextTestRunner(verbosity=2))