| #!/usr/bin/env python |
| |
| import argparse |
| import socket |
| import sys |
| |
| from util import add_common_args |
| from local_thrift import thrift |
| from thrift.Thrift import TMessageType, TType |
| from thrift.transport.TSocket import TSocket |
| from thrift.transport.TTransport import TBufferedTransport, TFramedTransport |
| from thrift.protocol.TBinaryProtocol import TBinaryProtocol |
| |
| |
| # THeader stack should accept binary protocol with optionally framed transport |
| def main(argv): |
| p = argparse.ArgumentParser() |
| add_common_args(p) |
| # Since THeaderTransport acts as framed transport when detected frame, we |
| # cannot use --transport=framed as it would result in 2 layered frames. |
| p.add_argument('--override-transport') |
| args = p.parse_args() |
| assert args.protocol == 'header' |
| assert args.transport == 'buffered' |
| assert not args.ssl |
| |
| sock = TSocket(args.host, args.port, socket_family=socket.AF_INET) |
| if not args.override_transport or args.override_transport == 'buffered': |
| trans = TBufferedTransport(sock) |
| elif args.override_transport == 'framed': |
| trans = TFramedTransport(sock) |
| else: |
| raise ValueError('invalid transport') |
| trans.open() |
| proto = TBinaryProtocol(trans) |
| proto.writeMessageBegin('testVoid', TMessageType.CALL, 3) |
| proto.writeStructBegin('testVoid_args') |
| proto.writeFieldStop() |
| proto.writeStructEnd() |
| proto.writeMessageEnd() |
| trans.flush() |
| |
| _, mtype, _ = proto.readMessageBegin() |
| assert mtype == TMessageType.REPLY |
| proto.readStructBegin() |
| _, ftype, _ = proto.readFieldBegin() |
| assert ftype == TType.STOP |
| proto.readFieldEnd() |
| proto.readStructEnd() |
| proto.readMessageEnd() |
| |
| trans.close() |
| |
| |
| if __name__ == '__main__': |
| sys.exit(main(sys.argv[1:])) |