# # 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. # use Test::More tests => 2; use strict; use warnings; use Thrift::BinaryProtocol; use Thrift::MemoryBuffer; use Thrift::MessageType; use ThriftTest::ThriftTest; use ThriftTest::Types; use Data::Dumper; my $buffer = Thrift::MemoryBuffer->new(1024); my $protocol = Thrift::BinaryProtocol->new($buffer); my $client = ThriftTest::ThriftTestClient->new($protocol); $buffer->open(); $client->send_testString("foo"); $client->{seqid}++; $client->send_testString("bar"); my $client_command_binary = $buffer->getBuffer; $buffer->resetBuffer; # Process by server my $server_output_binary; { my $protocol_factory = Thrift::BinaryProtocolFactory->new(); my $input_buffer = Thrift::MemoryBuffer->new(); $input_buffer->write($client_command_binary); my $input_protocol = $protocol_factory->getProtocol($input_buffer); my $output_buffer = Thrift::MemoryBuffer->new(); my $output_protocol = $protocol_factory->getProtocol($output_buffer); my $processor = ThriftTest::ThriftTestProcessor->new( My::ThriftTest->new() ); my $result = $processor->process($input_protocol, $output_protocol); print "process resulted in $result\n"; $result = $processor->process($input_protocol, $output_protocol); print "process resulted in $result\n"; $server_output_binary = $output_buffer->getBuffer(); } $buffer->write($server_output_binary); foreach my $val (("got foo","got bar")){ my ($function_name, $message_type, $sequence_id); $protocol->readMessageBegin(\$function_name, \$message_type, \$sequence_id); print " $function_name, $message_type, $sequence_id\n"; if ($message_type == Thrift::TMessageType::EXCEPTION) { die; } my $result = ThriftTest::ThriftTest_testString_result->new(); $result->read($protocol); $protocol->readMessageEnd(); is($result->success(),$val); } package My::ThriftTest; use strict; use warnings; use Data::Dumper; sub new { my $class = shift; return bless {}, $class; } sub testString { my ($self, $string) = @_; print __PACKAGE__ . "->testString()\n"; return "got ".$string; }