Mark Slee | fc89d39 | 2006-09-04 00:04:39 +0000 | [diff] [blame] | 1 | #!/usr/bin/python |
| 2 | |
| 3 | import sys |
| 4 | sys.path.append('./gen-py') |
| 5 | |
| 6 | import ThriftTest |
| 7 | from ThriftTest_types import * |
Mark Slee | c967656 | 2006-09-05 17:34:52 +0000 | [diff] [blame] | 8 | from thrift.transport import TTransport |
Mark Slee | fc89d39 | 2006-09-04 00:04:39 +0000 | [diff] [blame] | 9 | from thrift.transport import TSocket |
| 10 | from thrift.protocol import TBinaryProtocol |
| 11 | |
Mark Slee | a330265 | 2006-10-25 19:03:32 +0000 | [diff] [blame^] | 12 | import hotshot |
| 13 | from hotshot import stats |
| 14 | prof = None |
| 15 | |
| 16 | # Uncomment if you want to profile this biznizzy |
| 17 | #prof = hotshot.Profile('hotshot_thrift_stats') |
| 18 | #prof.start() |
| 19 | |
Mark Slee | c967656 | 2006-09-05 17:34:52 +0000 | [diff] [blame] | 20 | import timing |
| 21 | |
Mark Slee | a330265 | 2006-10-25 19:03:32 +0000 | [diff] [blame^] | 22 | host = 'localhost' |
| 23 | port = 9090 |
| 24 | framed = False |
| 25 | framedInput = True |
| 26 | argi = 1 |
| 27 | |
| 28 | # Parse args |
| 29 | while argi < len(sys.argv): |
| 30 | if sys.argv[argi] == '-h': |
| 31 | parts = sys.argv[argi+1].split(':') |
| 32 | host = parts[0] |
| 33 | port = int(parts[1]) |
| 34 | argi += 1 |
| 35 | elif sys.argv[argi] == '-f' or sys.argv[argi] == '-framed': |
| 36 | framed = True |
| 37 | elif sys.argv[argi] == '-fo': |
| 38 | framed = True |
| 39 | framedInput = False |
| 40 | argi += 1 |
| 41 | |
| 42 | # Make socket |
| 43 | socket = TSocket.TSocket(host, port) |
| 44 | |
| 45 | # Frame or buffer depending upon args |
| 46 | if framed: |
| 47 | transport = TTransport.TFramedTransport(socket, framedInput, True) |
| 48 | else: |
| 49 | transport = TTransport.TBufferedTransport(socket) |
| 50 | |
Mark Slee | fc89d39 | 2006-09-04 00:04:39 +0000 | [diff] [blame] | 51 | protocol = TBinaryProtocol.TBinaryProtocol() |
| 52 | client = ThriftTest.Client(transport, protocol) |
| 53 | |
Mark Slee | a330265 | 2006-10-25 19:03:32 +0000 | [diff] [blame^] | 54 | # Connect! |
Mark Slee | fc89d39 | 2006-09-04 00:04:39 +0000 | [diff] [blame] | 55 | transport.open() |
| 56 | |
Mark Slee | c967656 | 2006-09-05 17:34:52 +0000 | [diff] [blame] | 57 | # Start debug timing |
| 58 | timing.start() |
| 59 | |
Mark Slee | fc89d39 | 2006-09-04 00:04:39 +0000 | [diff] [blame] | 60 | print "testVoid()" |
| 61 | print client.testVoid() |
| 62 | |
Mark Slee | c967656 | 2006-09-05 17:34:52 +0000 | [diff] [blame] | 63 | print "testString('Python')" |
| 64 | print client.testString('Python') |
Mark Slee | fc89d39 | 2006-09-04 00:04:39 +0000 | [diff] [blame] | 65 | |
| 66 | print "testByte(63)" |
| 67 | print client.testByte(63) |
| 68 | |
Mark Slee | c967656 | 2006-09-05 17:34:52 +0000 | [diff] [blame] | 69 | print "testI32(-1)" |
| 70 | print client.testI32(-1) |
| 71 | |
Mark Slee | c98d050 | 2006-09-06 02:42:25 +0000 | [diff] [blame] | 72 | print "testI32(0)" |
| 73 | print client.testI32(0) |
| 74 | |
Mark Slee | c967656 | 2006-09-05 17:34:52 +0000 | [diff] [blame] | 75 | print "testI64(-34359738368)" |
| 76 | print client.testI64(-34359738368) |
| 77 | |
Mark Slee | c98d050 | 2006-09-06 02:42:25 +0000 | [diff] [blame] | 78 | print "testDouble(-5.235098235)" |
| 79 | print client.testDouble(-5.235098235) |
| 80 | |
Mark Slee | c967656 | 2006-09-05 17:34:52 +0000 | [diff] [blame] | 81 | print "testStruct({Zero, 1, -3, -5})" |
| 82 | x = Xtruct() |
| 83 | x.string_thing = "Zero" |
| 84 | x.byte_thing = 1 |
| 85 | x.i32_thing = -3 |
| 86 | x.i64_thing = -5 |
| 87 | x = client.testStruct(x) |
| 88 | print "{%s, %d, %d, %d}" % (x.string_thing, x.byte_thing, x.i32_thing, x.i64_thing) |
| 89 | |
Mark Slee | fc89d39 | 2006-09-04 00:04:39 +0000 | [diff] [blame] | 90 | print "testException('Safe')" |
| 91 | print client.testException('Safe') |
| 92 | |
Mark Slee | fc89d39 | 2006-09-04 00:04:39 +0000 | [diff] [blame] | 93 | try: |
Mark Slee | c967656 | 2006-09-05 17:34:52 +0000 | [diff] [blame] | 94 | print "textException('Xception')" |
Mark Slee | fc89d39 | 2006-09-04 00:04:39 +0000 | [diff] [blame] | 95 | print client.testException('Xception') |
Mark Slee | c967656 | 2006-09-05 17:34:52 +0000 | [diff] [blame] | 96 | |
Mark Slee | fc89d39 | 2006-09-04 00:04:39 +0000 | [diff] [blame] | 97 | except Xception, x: |
Mark Slee | c967656 | 2006-09-05 17:34:52 +0000 | [diff] [blame] | 98 | print "Xception (%d, %s)" % (x.errorCode, x.message) |
| 99 | |
| 100 | timing.finish() |
| 101 | print "Total time: %d microsecs" % timing.micro() |
Mark Slee | fc89d39 | 2006-09-04 00:04:39 +0000 | [diff] [blame] | 102 | |
Mark Slee | a330265 | 2006-10-25 19:03:32 +0000 | [diff] [blame^] | 103 | # Close! |
Mark Slee | fc89d39 | 2006-09-04 00:04:39 +0000 | [diff] [blame] | 104 | transport.close() |
Mark Slee | a330265 | 2006-10-25 19:03:32 +0000 | [diff] [blame^] | 105 | |
| 106 | # Profiler output |
| 107 | if prof != None: |
| 108 | prof.stop() |
| 109 | prof.close() |
| 110 | s = stats.load('hotshot_thrift_stats') |
| 111 | s.sort_stats('time').print_stats() |