auser-poolparty 1.3.1 → 1.3.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/VERSION.yml +1 -1
- data/bin/cloud-compile +6 -1
- data/config/jeweler.rb +1 -3
- data/lib/cloud_providers/cloud_provider_instance.rb +11 -1
- data/lib/dependency_resolvers/chef/resources/chef_recipe.rb +51 -0
- data/lib/dependency_resolvers/chef.rb +12 -3
- data/lib/mixins/callbacks.rb +6 -2
- data/lib/poolparty/plugins/apache2/passenger_site.rb +2 -2
- data/test/fixtures/chef/recipes/sudo/attributes/sudoers.rb +30 -0
- data/test/fixtures/chef/recipes/sudo/recipes/default.rb +33 -0
- data/test/fixtures/chef/recipes/sudo/templates/default/sudoers.erb +22 -0
- data/test/lib/dependency_resolvers/chef/resources/chef_recipe_test.rb +21 -0
- data/test/lib/dependency_resolvers/chef_test.rb +8 -1
- data/vendor/gems/thrift/CHANGELOG +1 -0
- data/vendor/gems/thrift/Makefile.am +25 -6
- data/vendor/gems/thrift/Manifest +81 -0
- data/vendor/gems/thrift/README +17 -111
- data/vendor/gems/thrift/Rakefile +104 -0
- data/vendor/gems/thrift/{lib/hs/Setup.lhs → benchmark/Benchmark.thrift} +5 -4
- data/vendor/gems/thrift/benchmark/benchmark.rb +271 -0
- data/vendor/gems/thrift/benchmark/client.rb +74 -0
- data/vendor/gems/thrift/benchmark/server.rb +82 -0
- data/vendor/gems/thrift/benchmark/thin_server.rb +44 -0
- data/vendor/gems/thrift/ext/binary_protocol_accelerated.c +474 -0
- data/vendor/gems/thrift/{lib/cocoa/src/protocol/TProtocolException.m → ext/binary_protocol_accelerated.h} +1 -4
- data/vendor/gems/thrift/ext/compact_protocol.c +665 -0
- data/vendor/gems/thrift/{lib/cocoa/src/protocol/TProtocolException.h → ext/compact_protocol.h} +1 -6
- data/vendor/gems/thrift/ext/constants.h +95 -0
- data/vendor/gems/thrift/{contrib/fb303/Makefile.am → ext/extconf.rb} +8 -13
- data/vendor/gems/thrift/{compiler/cpp/src/platform.h → ext/macros.h} +18 -13
- data/vendor/gems/thrift/ext/memory_buffer.c +76 -0
- data/vendor/gems/thrift/{lib/csharp/src/Protocol/TMessageType.cs → ext/memory_buffer.h} +2 -13
- data/vendor/gems/thrift/ext/protocol.c +185 -0
- data/vendor/gems/thrift/{lib/csharp/src/TProcessor.cs → ext/protocol.h} +2 -11
- data/vendor/gems/thrift/ext/struct.c +606 -0
- data/vendor/gems/thrift/ext/struct.h +67 -0
- data/vendor/gems/thrift/ext/thrift_native.c +194 -0
- data/vendor/gems/thrift/lib/thrift/client.rb +62 -0
- data/vendor/gems/thrift/{contrib/fb303/py/fb303_scripts/__init__.py → lib/thrift/core_ext/fixnum.rb} +13 -4
- data/vendor/gems/thrift/{contrib/fb303/global_footer.mk → lib/thrift/core_ext.rb} +4 -2
- data/vendor/gems/thrift/lib/thrift/exceptions.rb +82 -0
- data/vendor/gems/thrift/lib/thrift/processor.rb +57 -0
- data/vendor/gems/thrift/lib/thrift/protocol/base_protocol.rb +290 -0
- data/vendor/gems/thrift/lib/thrift/protocol/binary_protocol.rb +225 -0
- data/vendor/gems/thrift/{cleanup.sh → lib/thrift/protocol/binary_protocol_accelerated.rb} +19 -42
- data/vendor/gems/thrift/lib/thrift/protocol/compact_protocol.rb +422 -0
- data/vendor/gems/thrift/lib/thrift/serializer/deserializer.rb +33 -0
- data/vendor/gems/thrift/{bootstrap.sh → lib/thrift/serializer/serializer.rb} +17 -18
- data/vendor/gems/thrift/lib/thrift/server/base_server.rb +31 -0
- data/vendor/gems/thrift/lib/thrift/server/mongrel_http_server.rb +58 -0
- data/vendor/gems/thrift/lib/thrift/server/nonblocking_server.rb +296 -0
- data/vendor/gems/thrift/lib/thrift/server/simple_server.rb +43 -0
- data/vendor/gems/thrift/lib/thrift/server/thread_pool_server.rb +75 -0
- data/vendor/gems/thrift/lib/thrift/server/threaded_server.rb +47 -0
- data/vendor/gems/thrift/lib/thrift/struct.rb +298 -0
- data/vendor/gems/thrift/{contrib/fb303/bootstrap.sh → lib/thrift/thrift_native.rb} +5 -7
- data/vendor/gems/thrift/lib/{erl/Makefile → thrift/transport/base_server_transport.rb} +20 -20
- data/vendor/gems/thrift/lib/thrift/transport/base_transport.rb +70 -0
- data/vendor/gems/thrift/lib/thrift/transport/buffered_transport.rb +77 -0
- data/vendor/gems/thrift/lib/thrift/transport/framed_transport.rb +90 -0
- data/vendor/gems/thrift/lib/thrift/transport/http_client_transport.rb +45 -0
- data/vendor/gems/thrift/lib/thrift/transport/io_stream_transport.rb +39 -0
- data/vendor/gems/thrift/lib/thrift/transport/memory_buffer_transport.rb +96 -0
- data/vendor/gems/thrift/lib/thrift/transport/server_socket.rb +63 -0
- data/vendor/gems/thrift/lib/thrift/transport/socket.rb +136 -0
- data/vendor/gems/thrift/lib/{java/Makefile.am → thrift/transport/unix_server_socket.rb} +39 -17
- data/vendor/gems/thrift/{contrib/fb303/global_header.mk → lib/thrift/transport/unix_socket.rb} +23 -21
- data/vendor/gems/thrift/lib/thrift/types.rb +101 -0
- data/vendor/gems/thrift/lib/thrift.rb +59 -0
- data/vendor/gems/thrift/script/proto_benchmark.rb +121 -0
- data/vendor/gems/thrift/{lib/Makefile.am → script/read_struct.rb} +24 -36
- data/vendor/gems/thrift/{contrib/fb303/py/setup.py → script/write_struct.rb} +8 -5
- data/vendor/gems/thrift/setup.rb +1585 -0
- data/vendor/gems/thrift/spec/ThriftSpec.thrift +84 -0
- data/vendor/gems/thrift/spec/base_protocol_spec.rb +160 -0
- data/vendor/gems/thrift/spec/base_transport_spec.rb +351 -0
- data/vendor/gems/thrift/{contrib/fb303/py/Makefile.am → spec/binary_protocol_accelerated_spec.rb} +22 -25
- data/vendor/gems/thrift/spec/binary_protocol_spec.rb +63 -0
- data/vendor/gems/thrift/spec/binary_protocol_spec_shared.rb +375 -0
- data/vendor/gems/thrift/spec/client_spec.rb +100 -0
- data/vendor/gems/thrift/spec/compact_protocol_spec.rb +117 -0
- data/vendor/gems/thrift/spec/exception_spec.rb +142 -0
- data/vendor/gems/thrift/spec/http_client_spec.rb +49 -0
- data/vendor/gems/thrift/spec/mongrel_http_server_spec.rb +117 -0
- data/vendor/gems/thrift/spec/nonblocking_server_spec.rb +265 -0
- data/vendor/gems/thrift/spec/processor_spec.rb +83 -0
- data/vendor/gems/thrift/spec/serializer_spec.rb +69 -0
- data/vendor/gems/thrift/spec/server_socket_spec.rb +80 -0
- data/vendor/gems/thrift/spec/server_spec.rb +160 -0
- data/vendor/gems/thrift/spec/socket_spec.rb +61 -0
- data/vendor/gems/thrift/spec/socket_spec_shared.rb +104 -0
- data/vendor/gems/thrift/spec/spec_helper.rb +60 -0
- data/vendor/gems/thrift/spec/struct_spec.rb +252 -0
- data/vendor/gems/thrift/spec/types_spec.rb +116 -0
- data/vendor/gems/thrift/spec/unix_socket_spec.rb +108 -0
- data/vendor/gems/trollop/FAQ.txt +84 -0
- data/vendor/gems/trollop/History.txt +101 -0
- data/vendor/gems/trollop/Manifest.txt +7 -0
- data/vendor/gems/trollop/README.txt +40 -0
- data/vendor/gems/trollop/Rakefile +36 -0
- data/vendor/gems/trollop/lib/trollop.rb +739 -0
- data/vendor/gems/trollop/release-script.txt +13 -0
- data/vendor/gems/trollop/test/test_trollop.rb +1048 -0
- data/vendor/gems/trollop/www/index.html +172 -0
- metadata +123 -347
- data/vendor/gems/thrift/CHANGES +0 -35
- data/vendor/gems/thrift/CONTRIBUTORS +0 -77
- data/vendor/gems/thrift/DISCLAIMER +0 -6
- data/vendor/gems/thrift/LICENSE +0 -202
- data/vendor/gems/thrift/NEWS +0 -79
- data/vendor/gems/thrift/NOTICE +0 -26
- data/vendor/gems/thrift/aclocal/ax_boost_base.m4 +0 -198
- data/vendor/gems/thrift/aclocal/ax_javac_and_java.m4 +0 -107
- data/vendor/gems/thrift/aclocal/ax_lib_event.m4 +0 -194
- data/vendor/gems/thrift/aclocal/ax_lib_zlib.m4 +0 -173
- data/vendor/gems/thrift/aclocal/ax_signed_right_shift.m4 +0 -127
- data/vendor/gems/thrift/aclocal/ax_thrift_internal.m4 +0 -39
- data/vendor/gems/thrift/compiler/cpp/Makefile.am +0 -136
- data/vendor/gems/thrift/compiler/cpp/README +0 -39
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_cocoa_generator.cc +0 -2331
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_cpp_generator.cc +0 -3003
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_csharp_generator.cc +0 -1700
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_erl_generator.cc +0 -932
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_generator.cc +0 -173
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_generator.h +0 -321
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_hs_generator.cc +0 -1445
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_html_generator.cc +0 -637
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_java_generator.cc +0 -3069
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_ocaml_generator.cc +0 -1673
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_oop_generator.h +0 -77
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_perl_generator.cc +0 -1812
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_php_generator.cc +0 -2281
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_py_generator.cc +0 -2310
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_rb_generator.cc +0 -1114
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_st_generator.cc +0 -1071
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_xsd_generator.cc +0 -354
- data/vendor/gems/thrift/compiler/cpp/src/globals.h +0 -117
- data/vendor/gems/thrift/compiler/cpp/src/main.cc +0 -1207
- data/vendor/gems/thrift/compiler/cpp/src/main.h +0 -103
- data/vendor/gems/thrift/compiler/cpp/src/md5.c +0 -381
- data/vendor/gems/thrift/compiler/cpp/src/md5.h +0 -91
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_base_type.h +0 -137
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_const.h +0 -59
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_const_value.h +0 -121
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_container.h +0 -56
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_doc.h +0 -51
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_enum.h +0 -59
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_enum_value.h +0 -64
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_field.h +0 -150
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_function.h +0 -93
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_list.h +0 -56
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_map.h +0 -64
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_program.h +0 -223
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_scope.h +0 -86
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_service.h +0 -68
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_set.h +0 -55
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_struct.h +0 -127
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_type.h +0 -176
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_typedef.h +0 -70
- data/vendor/gems/thrift/compiler/cpp/src/thriftl.ll +0 -303
- data/vendor/gems/thrift/compiler/cpp/src/thrifty.yy +0 -1140
- data/vendor/gems/thrift/configure.ac +0 -255
- data/vendor/gems/thrift/contrib/fb303/LICENSE +0 -16
- data/vendor/gems/thrift/contrib/fb303/README +0 -37
- data/vendor/gems/thrift/contrib/fb303/acinclude.m4 +0 -258
- data/vendor/gems/thrift/contrib/fb303/aclocal/ax_boost_base.m4 +0 -198
- data/vendor/gems/thrift/contrib/fb303/configure.ac +0 -115
- data/vendor/gems/thrift/contrib/fb303/cpp/FacebookBase.cpp +0 -124
- data/vendor/gems/thrift/contrib/fb303/cpp/FacebookBase.h +0 -103
- data/vendor/gems/thrift/contrib/fb303/cpp/Makefile.am +0 -84
- data/vendor/gems/thrift/contrib/fb303/cpp/ServiceTracker.cpp +0 -481
- data/vendor/gems/thrift/contrib/fb303/cpp/ServiceTracker.h +0 -215
- data/vendor/gems/thrift/contrib/fb303/if/fb303.thrift +0 -112
- data/vendor/gems/thrift/contrib/fb303/java/FacebookBase.java +0 -103
- data/vendor/gems/thrift/contrib/fb303/java/build.xml +0 -84
- data/vendor/gems/thrift/contrib/fb303/php/FacebookBase.php +0 -89
- data/vendor/gems/thrift/contrib/fb303/py/fb303/FacebookBase.py +0 -82
- data/vendor/gems/thrift/contrib/fb303/py/fb303_scripts/fb303_simple_mgmt.py +0 -195
- data/vendor/gems/thrift/contrib/thrift.el +0 -126
- data/vendor/gems/thrift/contrib/thrift.spec +0 -206
- data/vendor/gems/thrift/contrib/thrift.vim +0 -91
- data/vendor/gems/thrift/contrib/thrift_dump.cpp +0 -91
- data/vendor/gems/thrift/doc/lgpl-2.1.txt +0 -504
- data/vendor/gems/thrift/doc/otp-base-license.txt +0 -20
- data/vendor/gems/thrift/doc/thrift.bnf +0 -96
- data/vendor/gems/thrift/doc/thrift.tex +0 -1057
- data/vendor/gems/thrift/lib/cocoa/README +0 -21
- data/vendor/gems/thrift/lib/cocoa/src/TApplicationException.h +0 -44
- data/vendor/gems/thrift/lib/cocoa/src/TApplicationException.m +0 -130
- data/vendor/gems/thrift/lib/cocoa/src/TException.h +0 -34
- data/vendor/gems/thrift/lib/cocoa/src/TException.m +0 -64
- data/vendor/gems/thrift/lib/cocoa/src/TProcessor.h +0 -29
- data/vendor/gems/thrift/lib/cocoa/src/TProcessorFactory.h +0 -27
- data/vendor/gems/thrift/lib/cocoa/src/TSharedProcessorFactory.h +0 -27
- data/vendor/gems/thrift/lib/cocoa/src/TSharedProcessorFactory.m +0 -51
- data/vendor/gems/thrift/lib/cocoa/src/protocol/TBinaryProtocol.h +0 -51
- data/vendor/gems/thrift/lib/cocoa/src/protocol/TBinaryProtocol.m +0 -477
- data/vendor/gems/thrift/lib/cocoa/src/protocol/TProtocol.h +0 -148
- data/vendor/gems/thrift/lib/cocoa/src/protocol/TProtocolFactory.h +0 -29
- data/vendor/gems/thrift/lib/cocoa/src/protocol/TProtocolUtil.h +0 -29
- data/vendor/gems/thrift/lib/cocoa/src/protocol/TProtocolUtil.m +0 -104
- data/vendor/gems/thrift/lib/cocoa/src/server/TSocketServer.h +0 -50
- data/vendor/gems/thrift/lib/cocoa/src/server/TSocketServer.m +0 -153
- data/vendor/gems/thrift/lib/cocoa/src/transport/THTTPClient.h +0 -42
- data/vendor/gems/thrift/lib/cocoa/src/transport/THTTPClient.m +0 -159
- data/vendor/gems/thrift/lib/cocoa/src/transport/TNSFileHandleTransport.h +0 -35
- data/vendor/gems/thrift/lib/cocoa/src/transport/TNSFileHandleTransport.m +0 -91
- data/vendor/gems/thrift/lib/cocoa/src/transport/TNSStreamTransport.h +0 -38
- data/vendor/gems/thrift/lib/cocoa/src/transport/TNSStreamTransport.m +0 -89
- data/vendor/gems/thrift/lib/cocoa/src/transport/TSocketClient.h +0 -32
- data/vendor/gems/thrift/lib/cocoa/src/transport/TSocketClient.m +0 -58
- data/vendor/gems/thrift/lib/cocoa/src/transport/TTransport.h +0 -36
- data/vendor/gems/thrift/lib/cocoa/src/transport/TTransportException.h +0 -30
- data/vendor/gems/thrift/lib/cocoa/src/transport/TTransportException.m +0 -43
- data/vendor/gems/thrift/lib/cpp/Makefile.am +0 -158
- data/vendor/gems/thrift/lib/cpp/README +0 -67
- data/vendor/gems/thrift/lib/cpp/src/TLogging.h +0 -163
- data/vendor/gems/thrift/lib/cpp/src/TProcessor.h +0 -53
- data/vendor/gems/thrift/lib/cpp/src/TReflectionLocal.h +0 -96
- data/vendor/gems/thrift/lib/cpp/src/Thrift.cpp +0 -148
- data/vendor/gems/thrift/lib/cpp/src/Thrift.h +0 -191
- data/vendor/gems/thrift/lib/cpp/src/concurrency/Exception.h +0 -60
- data/vendor/gems/thrift/lib/cpp/src/concurrency/FunctionRunner.h +0 -77
- data/vendor/gems/thrift/lib/cpp/src/concurrency/Monitor.cpp +0 -137
- data/vendor/gems/thrift/lib/cpp/src/concurrency/Monitor.h +0 -84
- data/vendor/gems/thrift/lib/cpp/src/concurrency/Mutex.cpp +0 -160
- data/vendor/gems/thrift/lib/cpp/src/concurrency/Mutex.h +0 -114
- data/vendor/gems/thrift/lib/cpp/src/concurrency/PosixThreadFactory.cpp +0 -314
- data/vendor/gems/thrift/lib/cpp/src/concurrency/PosixThreadFactory.h +0 -130
- data/vendor/gems/thrift/lib/cpp/src/concurrency/Thread.h +0 -125
- data/vendor/gems/thrift/lib/cpp/src/concurrency/ThreadManager.cpp +0 -493
- data/vendor/gems/thrift/lib/cpp/src/concurrency/ThreadManager.h +0 -169
- data/vendor/gems/thrift/lib/cpp/src/concurrency/TimerManager.cpp +0 -284
- data/vendor/gems/thrift/lib/cpp/src/concurrency/TimerManager.h +0 -122
- data/vendor/gems/thrift/lib/cpp/src/concurrency/Util.cpp +0 -55
- data/vendor/gems/thrift/lib/cpp/src/concurrency/Util.h +0 -100
- data/vendor/gems/thrift/lib/cpp/src/concurrency/test/Tests.cpp +0 -155
- data/vendor/gems/thrift/lib/cpp/src/concurrency/test/ThreadFactoryTests.h +0 -354
- data/vendor/gems/thrift/lib/cpp/src/concurrency/test/ThreadManagerTests.h +0 -379
- data/vendor/gems/thrift/lib/cpp/src/concurrency/test/TimerManagerTests.h +0 -155
- data/vendor/gems/thrift/lib/cpp/src/processor/PeekProcessor.cpp +0 -122
- data/vendor/gems/thrift/lib/cpp/src/processor/PeekProcessor.h +0 -77
- data/vendor/gems/thrift/lib/cpp/src/processor/StatsProcessor.h +0 -264
- data/vendor/gems/thrift/lib/cpp/src/protocol/TBase64Utils.cpp +0 -79
- data/vendor/gems/thrift/lib/cpp/src/protocol/TBase64Utils.h +0 -42
- data/vendor/gems/thrift/lib/cpp/src/protocol/TBinaryProtocol.cpp +0 -394
- data/vendor/gems/thrift/lib/cpp/src/protocol/TBinaryProtocol.h +0 -254
- data/vendor/gems/thrift/lib/cpp/src/protocol/TCompactProtocol.cpp +0 -736
- data/vendor/gems/thrift/lib/cpp/src/protocol/TCompactProtocol.h +0 -279
- data/vendor/gems/thrift/lib/cpp/src/protocol/TDebugProtocol.cpp +0 -346
- data/vendor/gems/thrift/lib/cpp/src/protocol/TDebugProtocol.h +0 -225
- data/vendor/gems/thrift/lib/cpp/src/protocol/TDenseProtocol.cpp +0 -762
- data/vendor/gems/thrift/lib/cpp/src/protocol/TDenseProtocol.h +0 -253
- data/vendor/gems/thrift/lib/cpp/src/protocol/TJSONProtocol.cpp +0 -998
- data/vendor/gems/thrift/lib/cpp/src/protocol/TJSONProtocol.h +0 -340
- data/vendor/gems/thrift/lib/cpp/src/protocol/TOneWayProtocol.h +0 -304
- data/vendor/gems/thrift/lib/cpp/src/protocol/TProtocol.h +0 -438
- data/vendor/gems/thrift/lib/cpp/src/protocol/TProtocolException.h +0 -104
- data/vendor/gems/thrift/lib/cpp/src/protocol/TProtocolTap.h +0 -187
- data/vendor/gems/thrift/lib/cpp/src/server/TNonblockingServer.cpp +0 -750
- data/vendor/gems/thrift/lib/cpp/src/server/TNonblockingServer.h +0 -435
- data/vendor/gems/thrift/lib/cpp/src/server/TServer.cpp +0 -38
- data/vendor/gems/thrift/lib/cpp/src/server/TServer.h +0 -213
- data/vendor/gems/thrift/lib/cpp/src/server/TSimpleServer.cpp +0 -118
- data/vendor/gems/thrift/lib/cpp/src/server/TSimpleServer.h +0 -70
- data/vendor/gems/thrift/lib/cpp/src/server/TThreadPoolServer.cpp +0 -217
- data/vendor/gems/thrift/lib/cpp/src/server/TThreadPoolServer.h +0 -79
- data/vendor/gems/thrift/lib/cpp/src/server/TThreadedServer.cpp +0 -243
- data/vendor/gems/thrift/lib/cpp/src/server/TThreadedServer.h +0 -74
- data/vendor/gems/thrift/lib/cpp/src/transport/TBufferTransports.cpp +0 -370
- data/vendor/gems/thrift/lib/cpp/src/transport/TBufferTransports.h +0 -667
- data/vendor/gems/thrift/lib/cpp/src/transport/TFDTransport.cpp +0 -77
- data/vendor/gems/thrift/lib/cpp/src/transport/TFDTransport.h +0 -73
- data/vendor/gems/thrift/lib/cpp/src/transport/TFileTransport.cpp +0 -953
- data/vendor/gems/thrift/lib/cpp/src/transport/TFileTransport.h +0 -442
- data/vendor/gems/thrift/lib/cpp/src/transport/THttpClient.cpp +0 -348
- data/vendor/gems/thrift/lib/cpp/src/transport/THttpClient.h +0 -111
- data/vendor/gems/thrift/lib/cpp/src/transport/TServerSocket.cpp +0 -368
- data/vendor/gems/thrift/lib/cpp/src/transport/TServerSocket.h +0 -76
- data/vendor/gems/thrift/lib/cpp/src/transport/TServerTransport.h +0 -92
- data/vendor/gems/thrift/lib/cpp/src/transport/TShortReadTransport.h +0 -96
- data/vendor/gems/thrift/lib/cpp/src/transport/TSimpleFileTransport.cpp +0 -54
- data/vendor/gems/thrift/lib/cpp/src/transport/TSimpleFileTransport.h +0 -41
- data/vendor/gems/thrift/lib/cpp/src/transport/TSocket.cpp +0 -591
- data/vendor/gems/thrift/lib/cpp/src/transport/TSocket.h +0 -242
- data/vendor/gems/thrift/lib/cpp/src/transport/TSocketPool.cpp +0 -235
- data/vendor/gems/thrift/lib/cpp/src/transport/TSocketPool.h +0 -191
- data/vendor/gems/thrift/lib/cpp/src/transport/TTransport.h +0 -224
- data/vendor/gems/thrift/lib/cpp/src/transport/TTransportException.cpp +0 -31
- data/vendor/gems/thrift/lib/cpp/src/transport/TTransportException.h +0 -117
- data/vendor/gems/thrift/lib/cpp/src/transport/TTransportUtils.cpp +0 -178
- data/vendor/gems/thrift/lib/cpp/src/transport/TTransportUtils.h +0 -287
- data/vendor/gems/thrift/lib/cpp/src/transport/TZlibTransport.cpp +0 -299
- data/vendor/gems/thrift/lib/cpp/src/transport/TZlibTransport.h +0 -219
- data/vendor/gems/thrift/lib/cpp/thrift-nb.pc.in +0 -30
- data/vendor/gems/thrift/lib/cpp/thrift-z.pc.in +0 -30
- data/vendor/gems/thrift/lib/cpp/thrift.pc.in +0 -29
- data/vendor/gems/thrift/lib/csharp/Makefile.am +0 -70
- data/vendor/gems/thrift/lib/csharp/README +0 -26
- data/vendor/gems/thrift/lib/csharp/ThriftMSBuildTask/Properties/AssemblyInfo.cs +0 -55
- data/vendor/gems/thrift/lib/csharp/ThriftMSBuildTask/ThriftBuild.cs +0 -242
- data/vendor/gems/thrift/lib/csharp/ThriftMSBuildTask/ThriftMSBuildTask.csproj +0 -62
- data/vendor/gems/thrift/lib/csharp/src/Collections/THashSet.cs +0 -142
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TBase.cs +0 -34
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TBinaryProtocol.cs +0 -392
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TField.cs +0 -58
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TList.cs +0 -50
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TMap.cs +0 -58
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TMessage.cs +0 -58
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TProtocol.cs +0 -87
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TProtocolException.cs +0 -61
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TProtocolFactory.cs +0 -29
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TProtocolUtil.cs +0 -94
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TSet.cs +0 -50
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TStruct.cs +0 -42
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TType.cs +0 -40
- data/vendor/gems/thrift/lib/csharp/src/Server/TServer.cs +0 -135
- data/vendor/gems/thrift/lib/csharp/src/Server/TSimpleServer.cs +0 -148
- data/vendor/gems/thrift/lib/csharp/src/Server/TThreadPoolServer.cs +0 -186
- data/vendor/gems/thrift/lib/csharp/src/Server/TThreadedServer.cs +0 -234
- data/vendor/gems/thrift/lib/csharp/src/TApplicationException.cs +0 -131
- data/vendor/gems/thrift/lib/csharp/src/Thrift.csproj +0 -73
- data/vendor/gems/thrift/lib/csharp/src/Thrift.sln +0 -35
- data/vendor/gems/thrift/lib/csharp/src/Transport/TBufferedTransport.cs +0 -100
- data/vendor/gems/thrift/lib/csharp/src/Transport/TServerSocket.cs +0 -157
- data/vendor/gems/thrift/lib/csharp/src/Transport/TServerTransport.cs +0 -39
- data/vendor/gems/thrift/lib/csharp/src/Transport/TSocket.cs +0 -144
- data/vendor/gems/thrift/lib/csharp/src/Transport/TStreamTransport.cs +0 -103
- data/vendor/gems/thrift/lib/csharp/src/Transport/TTransport.cs +0 -66
- data/vendor/gems/thrift/lib/csharp/src/Transport/TTransportException.cs +0 -64
- data/vendor/gems/thrift/lib/csharp/src/Transport/TTransportFactory.cs +0 -38
- data/vendor/gems/thrift/lib/erl/README +0 -56
- data/vendor/gems/thrift/lib/erl/build/beamver +0 -59
- data/vendor/gems/thrift/lib/erl/build/buildtargets.mk +0 -15
- data/vendor/gems/thrift/lib/erl/build/colors.mk +0 -24
- data/vendor/gems/thrift/lib/erl/build/docs.mk +0 -12
- data/vendor/gems/thrift/lib/erl/build/mime.types +0 -98
- data/vendor/gems/thrift/lib/erl/build/otp.mk +0 -146
- data/vendor/gems/thrift/lib/erl/build/otp_subdir.mk +0 -85
- data/vendor/gems/thrift/lib/erl/build/raw_test.mk +0 -29
- data/vendor/gems/thrift/lib/erl/include/thrift_constants.hrl +0 -54
- data/vendor/gems/thrift/lib/erl/include/thrift_protocol.hrl +0 -31
- data/vendor/gems/thrift/lib/erl/src/Makefile +0 -116
- data/vendor/gems/thrift/lib/erl/src/test_handler.erl +0 -26
- data/vendor/gems/thrift/lib/erl/src/test_service.erl +0 -29
- data/vendor/gems/thrift/lib/erl/src/thrift.app.src +0 -44
- data/vendor/gems/thrift/lib/erl/src/thrift.appup.src +0 -1
- data/vendor/gems/thrift/lib/erl/src/thrift_base64_transport.erl +0 -64
- data/vendor/gems/thrift/lib/erl/src/thrift_binary_protocol.erl +0 -325
- data/vendor/gems/thrift/lib/erl/src/thrift_buffered_transport.erl +0 -180
- data/vendor/gems/thrift/lib/erl/src/thrift_client.erl +0 -384
- data/vendor/gems/thrift/lib/erl/src/thrift_disk_log_transport.erl +0 -118
- data/vendor/gems/thrift/lib/erl/src/thrift_file_transport.erl +0 -87
- data/vendor/gems/thrift/lib/erl/src/thrift_framed_transport.erl +0 -208
- data/vendor/gems/thrift/lib/erl/src/thrift_http_transport.erl +0 -199
- data/vendor/gems/thrift/lib/erl/src/thrift_memory_buffer.erl +0 -164
- data/vendor/gems/thrift/lib/erl/src/thrift_processor.erl +0 -188
- data/vendor/gems/thrift/lib/erl/src/thrift_protocol.erl +0 -356
- data/vendor/gems/thrift/lib/erl/src/thrift_server.erl +0 -183
- data/vendor/gems/thrift/lib/erl/src/thrift_service.erl +0 -25
- data/vendor/gems/thrift/lib/erl/src/thrift_socket_server.erl +0 -249
- data/vendor/gems/thrift/lib/erl/src/thrift_socket_transport.erl +0 -119
- data/vendor/gems/thrift/lib/erl/src/thrift_transport.erl +0 -57
- data/vendor/gems/thrift/lib/erl/vsn.mk +0 -1
- data/vendor/gems/thrift/lib/hs/README +0 -82
- data/vendor/gems/thrift/lib/hs/TODO +0 -2
- data/vendor/gems/thrift/lib/hs/Thrift.cabal +0 -20
- data/vendor/gems/thrift/lib/hs/src/Thrift/Protocol/Binary.hs +0 -147
- data/vendor/gems/thrift/lib/hs/src/Thrift/Protocol.hs +0 -191
- data/vendor/gems/thrift/lib/hs/src/Thrift/Server.hs +0 -65
- data/vendor/gems/thrift/lib/hs/src/Thrift/Transport/Handle.hs +0 -58
- data/vendor/gems/thrift/lib/hs/src/Thrift/Transport.hs +0 -60
- data/vendor/gems/thrift/lib/hs/src/Thrift.hs +0 -111
- data/vendor/gems/thrift/lib/java/README +0 -43
- data/vendor/gems/thrift/lib/java/build.xml +0 -195
- data/vendor/gems/thrift/lib/java/ivy.xml +0 -8
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/IntRangeSet.java +0 -171
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TApplicationException.java +0 -123
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TBase.java +0 -66
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TBaseHelper.java +0 -102
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TByteArrayOutputStream.java +0 -46
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TDeserializer.java +0 -94
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TException.java +0 -45
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TFieldRequirementType.java +0 -30
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TProcessor.java +0 -32
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TProcessorFactory.java +0 -39
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TSerializer.java +0 -110
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/meta_data/FieldMetaData.java +0 -69
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/meta_data/FieldValueMetaData.java +0 -42
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/meta_data/ListMetaData.java +0 -29
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/meta_data/MapMetaData.java +0 -31
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/meta_data/SetMetaData.java +0 -29
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/meta_data/StructMetaData.java +0 -31
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TBase64Utils.java +0 -128
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TBinaryProtocol.java +0 -331
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TCompactProtocol.java +0 -741
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TField.java +0 -48
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TJSONProtocol.java +0 -927
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TList.java +0 -38
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TMap.java +0 -40
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TMessage.java +0 -48
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TMessageType.java +0 -31
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TProtocol.java +0 -146
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TProtocolException.java +0 -81
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TProtocolFactory.java +0 -30
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TProtocolUtil.java +0 -158
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TSet.java +0 -42
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TSimpleJSONProtocol.java +0 -384
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TStruct.java +0 -36
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TType.java +0 -40
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/server/THsHaServer.java +0 -304
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/server/TNonblockingServer.java +0 -772
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/server/TServer.java +0 -126
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/server/TSimpleServer.java +0 -145
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/server/TThreadPoolServer.java +0 -271
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/TFramedTransport.java +0 -126
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/THttpClient.java +0 -157
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/TIOStreamTransport.java +0 -159
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/TMemoryBuffer.java +0 -98
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/TNonblockingServerSocket.java +0 -160
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/TNonblockingServerTransport.java +0 -31
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/TNonblockingSocket.java +0 -213
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/TNonblockingTransport.java +0 -31
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/TServerSocket.java +0 -145
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
#
|
|
2
|
+
# Licensed to the Apache Software Foundation (ASF) under one
|
|
3
|
+
# or more contributor license agreements. See the NOTICE file
|
|
4
|
+
# distributed with this work for additional information
|
|
5
|
+
# regarding copyright ownership. The ASF licenses this file
|
|
6
|
+
# to you under the Apache License, Version 2.0 (the
|
|
7
|
+
# "License"); you may not use this file except in compliance
|
|
8
|
+
# with the License. You may obtain a copy of the License at
|
|
9
|
+
#
|
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
11
|
+
#
|
|
12
|
+
# Unless required by applicable law or agreed to in writing,
|
|
13
|
+
# software distributed under the License is distributed on an
|
|
14
|
+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
15
|
+
# KIND, either express or implied. See the License for the
|
|
16
|
+
# specific language governing permissions and limitations
|
|
17
|
+
# under the License.
|
|
18
|
+
#
|
|
19
|
+
|
|
20
|
+
require 'rubygems'
|
|
21
|
+
require 'rake'
|
|
22
|
+
require 'spec/rake/spectask'
|
|
23
|
+
|
|
24
|
+
THRIFT = '../../compiler/cpp/thrift'
|
|
25
|
+
|
|
26
|
+
task :default => [:spec]
|
|
27
|
+
|
|
28
|
+
task :spec => [:'gen-rb', :realspec]
|
|
29
|
+
|
|
30
|
+
Spec::Rake::SpecTask.new(:realspec) do |t|
|
|
31
|
+
t.spec_files = FileList['spec/**/*_spec.rb']
|
|
32
|
+
t.spec_opts = ['--color']
|
|
33
|
+
end
|
|
34
|
+
|
|
35
|
+
Spec::Rake::SpecTask.new(:'spec:rcov') do |t|
|
|
36
|
+
t.spec_files = FileList['spec/**/*_spec.rb']
|
|
37
|
+
t.spec_opts = ['--color']
|
|
38
|
+
t.rcov = true
|
|
39
|
+
t.rcov_opts = ['--exclude', '^spec,/gems/']
|
|
40
|
+
end
|
|
41
|
+
|
|
42
|
+
desc 'Run the compiler tests (requires full thrift checkout)'
|
|
43
|
+
task :test do
|
|
44
|
+
# ensure this is a full thrift checkout and not a tarball of the ruby libs
|
|
45
|
+
cmd = 'head -1 ../../README 2>/dev/null | grep Thrift >/dev/null 2>/dev/null'
|
|
46
|
+
system(cmd) or fail "rake test requires a full thrift checkout"
|
|
47
|
+
sh 'make', '-C', File.dirname(__FILE__) + "/../../test/rb", "check"
|
|
48
|
+
end
|
|
49
|
+
|
|
50
|
+
desc 'Compile the .thrift files for the specs'
|
|
51
|
+
task :'gen-rb' => [:'gen-rb:spec', :'gen-rb:benchmark', :'gen-rb:debug_proto']
|
|
52
|
+
|
|
53
|
+
namespace :'gen-rb' do
|
|
54
|
+
task :'spec' do
|
|
55
|
+
dir = File.dirname(__FILE__) + '/spec'
|
|
56
|
+
sh THRIFT, '--gen', 'rb', '-o', dir, "#{dir}/ThriftSpec.thrift"
|
|
57
|
+
end
|
|
58
|
+
|
|
59
|
+
task :'benchmark' do
|
|
60
|
+
dir = File.dirname(__FILE__) + '/benchmark'
|
|
61
|
+
sh THRIFT, '--gen', 'rb', '-o', dir, "#{dir}/Benchmark.thrift"
|
|
62
|
+
end
|
|
63
|
+
|
|
64
|
+
task :'debug_proto' do
|
|
65
|
+
sh "mkdir", "-p", "debug_proto_test"
|
|
66
|
+
sh THRIFT, '--gen', 'rb', "-o", "debug_proto_test", "../../test/DebugProtoTest.thrift"
|
|
67
|
+
end
|
|
68
|
+
end
|
|
69
|
+
|
|
70
|
+
desc 'Run benchmarking of NonblockingServer'
|
|
71
|
+
task :benchmark do
|
|
72
|
+
ruby 'benchmark/benchmark.rb'
|
|
73
|
+
end
|
|
74
|
+
|
|
75
|
+
|
|
76
|
+
begin
|
|
77
|
+
require 'echoe'
|
|
78
|
+
|
|
79
|
+
Echoe.new('thrift') do |p|
|
|
80
|
+
p.author = ['Kevin Ballard', 'Kevin Clark', 'Mark Slee']
|
|
81
|
+
p.email = ['kevin@sb.org', 'kevin.clark@gmail.com', 'mcslee@facebook.com']
|
|
82
|
+
p.summary = "Ruby libraries for Thrift (a language-agnostic RPC system)"
|
|
83
|
+
p.url = "http://incubator.apache.org/thrift/"
|
|
84
|
+
p.include_rakefile = true
|
|
85
|
+
p.version = "0.1.0"
|
|
86
|
+
p.rubygems_version = ">= 1.2.0"
|
|
87
|
+
end
|
|
88
|
+
|
|
89
|
+
task :install => [:check_site_lib]
|
|
90
|
+
|
|
91
|
+
require 'rbconfig'
|
|
92
|
+
task :check_site_lib do
|
|
93
|
+
if File.exist?(File.join(Config::CONFIG['sitelibdir'], 'thrift.rb'))
|
|
94
|
+
fail "thrift is already installed in site_ruby"
|
|
95
|
+
end
|
|
96
|
+
end
|
|
97
|
+
rescue LoadError
|
|
98
|
+
[:install, :package].each do |t|
|
|
99
|
+
desc "Stub for #{t}"
|
|
100
|
+
task t do
|
|
101
|
+
fail "The Echoe gem is required for this task"
|
|
102
|
+
end
|
|
103
|
+
end
|
|
104
|
+
end
|
|
@@ -1,5 +1,3 @@
|
|
|
1
|
-
#!/usr/bin/env runhaskell
|
|
2
|
-
|
|
3
1
|
#
|
|
4
2
|
# Licensed to the Apache Software Foundation (ASF) under one
|
|
5
3
|
# or more contributor license agreements. See the NOTICE file
|
|
@@ -19,5 +17,8 @@
|
|
|
19
17
|
# under the License.
|
|
20
18
|
#
|
|
21
19
|
|
|
22
|
-
|
|
23
|
-
|
|
20
|
+
namespace rb ThriftBenchmark
|
|
21
|
+
|
|
22
|
+
service BenchmarkService {
|
|
23
|
+
i32 fibonacci(1:byte n)
|
|
24
|
+
}
|
|
@@ -0,0 +1,271 @@
|
|
|
1
|
+
#
|
|
2
|
+
# Licensed to the Apache Software Foundation (ASF) under one
|
|
3
|
+
# or more contributor license agreements. See the NOTICE file
|
|
4
|
+
# distributed with this work for additional information
|
|
5
|
+
# regarding copyright ownership. The ASF licenses this file
|
|
6
|
+
# to you under the Apache License, Version 2.0 (the
|
|
7
|
+
# "License"); you may not use this file except in compliance
|
|
8
|
+
# with the License. You may obtain a copy of the License at
|
|
9
|
+
#
|
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
11
|
+
#
|
|
12
|
+
# Unless required by applicable law or agreed to in writing,
|
|
13
|
+
# software distributed under the License is distributed on an
|
|
14
|
+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
15
|
+
# KIND, either express or implied. See the License for the
|
|
16
|
+
# specific language governing permissions and limitations
|
|
17
|
+
# under the License.
|
|
18
|
+
#
|
|
19
|
+
|
|
20
|
+
require 'rubygems'
|
|
21
|
+
$:.unshift File.dirname(__FILE__) + '/../lib'
|
|
22
|
+
require 'thrift'
|
|
23
|
+
require 'stringio'
|
|
24
|
+
|
|
25
|
+
HOST = '127.0.0.1'
|
|
26
|
+
PORT = 42587
|
|
27
|
+
|
|
28
|
+
###############
|
|
29
|
+
## Server
|
|
30
|
+
###############
|
|
31
|
+
|
|
32
|
+
class Server
|
|
33
|
+
attr_accessor :serverclass
|
|
34
|
+
attr_accessor :interpreter
|
|
35
|
+
attr_accessor :host
|
|
36
|
+
attr_accessor :port
|
|
37
|
+
|
|
38
|
+
def initialize(opts)
|
|
39
|
+
@serverclass = opts.fetch(:class, Thrift::NonblockingServer)
|
|
40
|
+
@interpreter = opts.fetch(:interpreter, "ruby")
|
|
41
|
+
@host = opts.fetch(:host, ::HOST)
|
|
42
|
+
@port = opts.fetch(:port, ::PORT)
|
|
43
|
+
end
|
|
44
|
+
|
|
45
|
+
def start
|
|
46
|
+
return if @serverclass == Object
|
|
47
|
+
args = (File.basename(@interpreter) == "jruby" ? "-J-server" : "")
|
|
48
|
+
@pipe = IO.popen("#{@interpreter} #{args} #{File.dirname(__FILE__)}/server.rb #{@host} #{@port} #{@serverclass.name}", "r+")
|
|
49
|
+
Marshal.load(@pipe) # wait until the server has started
|
|
50
|
+
sleep 0.4 # give the server time to actually start spawning sockets
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
def shutdown
|
|
54
|
+
return unless @pipe
|
|
55
|
+
Marshal.dump(:shutdown, @pipe)
|
|
56
|
+
begin
|
|
57
|
+
@pipe.read(10) # block until the server shuts down
|
|
58
|
+
rescue EOFError
|
|
59
|
+
end
|
|
60
|
+
@pipe.close
|
|
61
|
+
@pipe = nil
|
|
62
|
+
end
|
|
63
|
+
end
|
|
64
|
+
|
|
65
|
+
class BenchmarkManager
|
|
66
|
+
def initialize(opts, server)
|
|
67
|
+
@socket = opts.fetch(:socket) do
|
|
68
|
+
@host = opts.fetch(:host, 'localhost')
|
|
69
|
+
@port = opts.fetch(:port)
|
|
70
|
+
nil
|
|
71
|
+
end
|
|
72
|
+
@num_processes = opts.fetch(:num_processes, 40)
|
|
73
|
+
@clients_per_process = opts.fetch(:clients_per_process, 10)
|
|
74
|
+
@calls_per_client = opts.fetch(:calls_per_client, 50)
|
|
75
|
+
@interpreter = opts.fetch(:interpreter, "ruby")
|
|
76
|
+
@server = server
|
|
77
|
+
@log_exceptions = opts.fetch(:log_exceptions, false)
|
|
78
|
+
end
|
|
79
|
+
|
|
80
|
+
def run
|
|
81
|
+
@pool = []
|
|
82
|
+
@benchmark_start = Time.now
|
|
83
|
+
puts "Spawning benchmark processes..."
|
|
84
|
+
@num_processes.times do
|
|
85
|
+
spawn
|
|
86
|
+
sleep 0.02 # space out spawns
|
|
87
|
+
end
|
|
88
|
+
collect_output
|
|
89
|
+
@benchmark_end = Time.now # we know the procs are done here
|
|
90
|
+
translate_output
|
|
91
|
+
analyze_output
|
|
92
|
+
report_output
|
|
93
|
+
end
|
|
94
|
+
|
|
95
|
+
def spawn
|
|
96
|
+
pipe = IO.popen("#{@interpreter} #{File.dirname(__FILE__)}/client.rb #{"-log-exceptions" if @log_exceptions} #{@host} #{@port} #{@clients_per_process} #{@calls_per_client}")
|
|
97
|
+
@pool << pipe
|
|
98
|
+
end
|
|
99
|
+
|
|
100
|
+
def socket_class
|
|
101
|
+
if @socket
|
|
102
|
+
Thrift::UNIXSocket
|
|
103
|
+
else
|
|
104
|
+
Thrift::Socket
|
|
105
|
+
end
|
|
106
|
+
end
|
|
107
|
+
|
|
108
|
+
def collect_output
|
|
109
|
+
puts "Collecting output..."
|
|
110
|
+
# read from @pool until all sockets are closed
|
|
111
|
+
@buffers = Hash.new { |h,k| h[k] = '' }
|
|
112
|
+
until @pool.empty?
|
|
113
|
+
rd, = select(@pool)
|
|
114
|
+
next if rd.nil?
|
|
115
|
+
rd.each do |fd|
|
|
116
|
+
begin
|
|
117
|
+
@buffers[fd] << fd.readpartial(4096)
|
|
118
|
+
rescue EOFError
|
|
119
|
+
@pool.delete fd
|
|
120
|
+
end
|
|
121
|
+
end
|
|
122
|
+
end
|
|
123
|
+
end
|
|
124
|
+
|
|
125
|
+
def translate_output
|
|
126
|
+
puts "Translating output..."
|
|
127
|
+
@output = []
|
|
128
|
+
@buffers.each do |fd, buffer|
|
|
129
|
+
strio = StringIO.new(buffer)
|
|
130
|
+
logs = []
|
|
131
|
+
begin
|
|
132
|
+
loop do
|
|
133
|
+
logs << Marshal.load(strio)
|
|
134
|
+
end
|
|
135
|
+
rescue EOFError
|
|
136
|
+
@output << logs
|
|
137
|
+
end
|
|
138
|
+
end
|
|
139
|
+
end
|
|
140
|
+
|
|
141
|
+
def analyze_output
|
|
142
|
+
puts "Analyzing output..."
|
|
143
|
+
call_times = []
|
|
144
|
+
client_times = []
|
|
145
|
+
connection_failures = []
|
|
146
|
+
connection_errors = []
|
|
147
|
+
shortest_call = 0
|
|
148
|
+
shortest_client = 0
|
|
149
|
+
longest_call = 0
|
|
150
|
+
longest_client = 0
|
|
151
|
+
@output.each do |logs|
|
|
152
|
+
cur_call, cur_client = nil
|
|
153
|
+
logs.each do |tok, time|
|
|
154
|
+
case tok
|
|
155
|
+
when :start
|
|
156
|
+
cur_client = time
|
|
157
|
+
when :call_start
|
|
158
|
+
cur_call = time
|
|
159
|
+
when :call_end
|
|
160
|
+
delta = time - cur_call
|
|
161
|
+
call_times << delta
|
|
162
|
+
longest_call = delta unless longest_call > delta
|
|
163
|
+
shortest_call = delta if shortest_call == 0 or delta < shortest_call
|
|
164
|
+
cur_call = nil
|
|
165
|
+
when :end
|
|
166
|
+
delta = time - cur_client
|
|
167
|
+
client_times << delta
|
|
168
|
+
longest_client = delta unless longest_client > delta
|
|
169
|
+
shortest_client = delta if shortest_client == 0 or delta < shortest_client
|
|
170
|
+
cur_client = nil
|
|
171
|
+
when :connection_failure
|
|
172
|
+
connection_failures << time
|
|
173
|
+
when :connection_error
|
|
174
|
+
connection_errors << time
|
|
175
|
+
end
|
|
176
|
+
end
|
|
177
|
+
end
|
|
178
|
+
@report = {}
|
|
179
|
+
@report[:total_calls] = call_times.inject(0.0) { |a,t| a += t }
|
|
180
|
+
@report[:avg_calls] = @report[:total_calls] / call_times.size
|
|
181
|
+
@report[:total_clients] = client_times.inject(0.0) { |a,t| a += t }
|
|
182
|
+
@report[:avg_clients] = @report[:total_clients] / client_times.size
|
|
183
|
+
@report[:connection_failures] = connection_failures.size
|
|
184
|
+
@report[:connection_errors] = connection_errors.size
|
|
185
|
+
@report[:shortest_call] = shortest_call
|
|
186
|
+
@report[:shortest_client] = shortest_client
|
|
187
|
+
@report[:longest_call] = longest_call
|
|
188
|
+
@report[:longest_client] = longest_client
|
|
189
|
+
@report[:total_benchmark_time] = @benchmark_end - @benchmark_start
|
|
190
|
+
@report[:fastthread] = $".include?('fastthread.bundle')
|
|
191
|
+
end
|
|
192
|
+
|
|
193
|
+
def report_output
|
|
194
|
+
fmt = "%.4f seconds"
|
|
195
|
+
puts
|
|
196
|
+
tabulate "%d",
|
|
197
|
+
[["Server class", "%s"], @server.serverclass == Object ? "" : @server.serverclass],
|
|
198
|
+
[["Server interpreter", "%s"], @server.interpreter],
|
|
199
|
+
[["Client interpreter", "%s"], @interpreter],
|
|
200
|
+
[["Socket class", "%s"], socket_class],
|
|
201
|
+
["Number of processes", @num_processes],
|
|
202
|
+
["Clients per process", @clients_per_process],
|
|
203
|
+
["Calls per client", @calls_per_client],
|
|
204
|
+
[["Using fastthread", "%s"], @report[:fastthread] ? "yes" : "no"]
|
|
205
|
+
puts
|
|
206
|
+
failures = (@report[:connection_failures] > 0)
|
|
207
|
+
tabulate fmt,
|
|
208
|
+
[["Connection failures", "%d", [:red, :bold]], @report[:connection_failures]],
|
|
209
|
+
[["Connection errors", "%d", [:red, :bold]], @report[:connection_errors]],
|
|
210
|
+
["Average time per call", @report[:avg_calls]],
|
|
211
|
+
["Average time per client (%d calls)" % @calls_per_client, @report[:avg_clients]],
|
|
212
|
+
["Total time for all calls", @report[:total_calls]],
|
|
213
|
+
["Real time for benchmarking", @report[:total_benchmark_time]],
|
|
214
|
+
["Shortest call time", @report[:shortest_call]],
|
|
215
|
+
["Longest call time", @report[:longest_call]],
|
|
216
|
+
["Shortest client time (%d calls)" % @calls_per_client, @report[:shortest_client]],
|
|
217
|
+
["Longest client time (%d calls)" % @calls_per_client, @report[:longest_client]]
|
|
218
|
+
end
|
|
219
|
+
|
|
220
|
+
ANSI = {
|
|
221
|
+
:reset => 0,
|
|
222
|
+
:bold => 1,
|
|
223
|
+
:black => 30,
|
|
224
|
+
:red => 31,
|
|
225
|
+
:green => 32,
|
|
226
|
+
:yellow => 33,
|
|
227
|
+
:blue => 34,
|
|
228
|
+
:magenta => 35,
|
|
229
|
+
:cyan => 36,
|
|
230
|
+
:white => 37
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
def tabulate(fmt, *labels_and_values)
|
|
234
|
+
labels = labels_and_values.map { |l| Array === l ? l.first : l }
|
|
235
|
+
label_width = labels.inject(0) { |w,l| l.size > w ? l.size : w }
|
|
236
|
+
labels_and_values.each do |(l,v)|
|
|
237
|
+
f = fmt
|
|
238
|
+
l, f, c = l if Array === l
|
|
239
|
+
fmtstr = "%-#{label_width+1}s #{f}"
|
|
240
|
+
if STDOUT.tty? and c and v.to_i > 0
|
|
241
|
+
fmtstr = "\e[#{[*c].map { |x| ANSI[x] } * ";"}m" + fmtstr + "\e[#{ANSI[:reset]}m"
|
|
242
|
+
end
|
|
243
|
+
puts fmtstr % [l+":", v]
|
|
244
|
+
end
|
|
245
|
+
end
|
|
246
|
+
end
|
|
247
|
+
|
|
248
|
+
def resolve_const(const)
|
|
249
|
+
const and const.split('::').inject(Object) { |k,c| k.const_get(c) }
|
|
250
|
+
end
|
|
251
|
+
|
|
252
|
+
puts "Starting server..."
|
|
253
|
+
args = {}
|
|
254
|
+
args[:interpreter] = ENV['THRIFT_SERVER_INTERPRETER'] || ENV['THRIFT_INTERPRETER'] || "ruby"
|
|
255
|
+
args[:class] = resolve_const(ENV['THRIFT_SERVER']) || Thrift::NonblockingServer
|
|
256
|
+
args[:host] = ENV['THRIFT_HOST'] || HOST
|
|
257
|
+
args[:port] = (ENV['THRIFT_PORT'] || PORT).to_i
|
|
258
|
+
server = Server.new(args)
|
|
259
|
+
server.start
|
|
260
|
+
|
|
261
|
+
args = {}
|
|
262
|
+
args[:host] = ENV['THRIFT_HOST'] || HOST
|
|
263
|
+
args[:port] = (ENV['THRIFT_PORT'] || PORT).to_i
|
|
264
|
+
args[:num_processes] = (ENV['THRIFT_NUM_PROCESSES'] || 40).to_i
|
|
265
|
+
args[:clients_per_process] = (ENV['THRIFT_NUM_CLIENTS'] || 5).to_i
|
|
266
|
+
args[:calls_per_client] = (ENV['THRIFT_NUM_CALLS'] || 50).to_i
|
|
267
|
+
args[:interpreter] = ENV['THRIFT_CLIENT_INTERPRETER'] || ENV['THRIFT_INTERPRETER'] || "ruby"
|
|
268
|
+
args[:log_exceptions] = !!ENV['THRIFT_LOG_EXCEPTIONS']
|
|
269
|
+
BenchmarkManager.new(args, server).run
|
|
270
|
+
|
|
271
|
+
server.shutdown
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
#
|
|
2
|
+
# Licensed to the Apache Software Foundation (ASF) under one
|
|
3
|
+
# or more contributor license agreements. See the NOTICE file
|
|
4
|
+
# distributed with this work for additional information
|
|
5
|
+
# regarding copyright ownership. The ASF licenses this file
|
|
6
|
+
# to you under the Apache License, Version 2.0 (the
|
|
7
|
+
# "License"); you may not use this file except in compliance
|
|
8
|
+
# with the License. You may obtain a copy of the License at
|
|
9
|
+
#
|
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
11
|
+
#
|
|
12
|
+
# Unless required by applicable law or agreed to in writing,
|
|
13
|
+
# software distributed under the License is distributed on an
|
|
14
|
+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
15
|
+
# KIND, either express or implied. See the License for the
|
|
16
|
+
# specific language governing permissions and limitations
|
|
17
|
+
# under the License.
|
|
18
|
+
#
|
|
19
|
+
|
|
20
|
+
$:.unshift File.dirname(__FILE__) + '/../lib'
|
|
21
|
+
require 'thrift'
|
|
22
|
+
$:.unshift File.dirname(__FILE__) + "/gen-rb"
|
|
23
|
+
require 'benchmark_service'
|
|
24
|
+
|
|
25
|
+
class Client
|
|
26
|
+
def initialize(host, port, clients_per_process, calls_per_client, log_exceptions)
|
|
27
|
+
@host = host
|
|
28
|
+
@port = port
|
|
29
|
+
@clients_per_process = clients_per_process
|
|
30
|
+
@calls_per_client = calls_per_client
|
|
31
|
+
@log_exceptions = log_exceptions
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
def run
|
|
35
|
+
@clients_per_process.times do
|
|
36
|
+
socket = Thrift::Socket.new(@host, @port)
|
|
37
|
+
transport = Thrift::FramedTransport.new(socket)
|
|
38
|
+
protocol = Thrift::BinaryProtocol.new(transport)
|
|
39
|
+
client = ThriftBenchmark::BenchmarkService::Client.new(protocol)
|
|
40
|
+
begin
|
|
41
|
+
start = Time.now
|
|
42
|
+
transport.open
|
|
43
|
+
Marshal.dump [:start, start], STDOUT
|
|
44
|
+
rescue => e
|
|
45
|
+
Marshal.dump [:connection_failure, Time.now], STDOUT
|
|
46
|
+
print_exception e if @log_exceptions
|
|
47
|
+
else
|
|
48
|
+
begin
|
|
49
|
+
@calls_per_client.times do
|
|
50
|
+
Marshal.dump [:call_start, Time.now], STDOUT
|
|
51
|
+
client.fibonacci(15)
|
|
52
|
+
Marshal.dump [:call_end, Time.now], STDOUT
|
|
53
|
+
end
|
|
54
|
+
transport.close
|
|
55
|
+
Marshal.dump [:end, Time.now], STDOUT
|
|
56
|
+
rescue Thrift::TransportException => e
|
|
57
|
+
Marshal.dump [:connection_error, Time.now], STDOUT
|
|
58
|
+
print_exception e if @log_exceptions
|
|
59
|
+
end
|
|
60
|
+
end
|
|
61
|
+
end
|
|
62
|
+
end
|
|
63
|
+
|
|
64
|
+
def print_exception(e)
|
|
65
|
+
STDERR.puts "ERROR: #{e.message}"
|
|
66
|
+
STDERR.puts "\t#{e.backtrace * "\n\t"}"
|
|
67
|
+
end
|
|
68
|
+
end
|
|
69
|
+
|
|
70
|
+
log_exceptions = true if ARGV[0] == '-log-exceptions' and ARGV.shift
|
|
71
|
+
|
|
72
|
+
host, port, clients_per_process, calls_per_client = ARGV
|
|
73
|
+
|
|
74
|
+
Client.new(host, port.to_i, clients_per_process.to_i, calls_per_client.to_i, log_exceptions).run
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
#
|
|
2
|
+
# Licensed to the Apache Software Foundation (ASF) under one
|
|
3
|
+
# or more contributor license agreements. See the NOTICE file
|
|
4
|
+
# distributed with this work for additional information
|
|
5
|
+
# regarding copyright ownership. The ASF licenses this file
|
|
6
|
+
# to you under the Apache License, Version 2.0 (the
|
|
7
|
+
# "License"); you may not use this file except in compliance
|
|
8
|
+
# with the License. You may obtain a copy of the License at
|
|
9
|
+
#
|
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
11
|
+
#
|
|
12
|
+
# Unless required by applicable law or agreed to in writing,
|
|
13
|
+
# software distributed under the License is distributed on an
|
|
14
|
+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
15
|
+
# KIND, either express or implied. See the License for the
|
|
16
|
+
# specific language governing permissions and limitations
|
|
17
|
+
# under the License.
|
|
18
|
+
#
|
|
19
|
+
|
|
20
|
+
$:.unshift File.dirname(__FILE__) + '/../lib'
|
|
21
|
+
require 'thrift'
|
|
22
|
+
$:.unshift File.dirname(__FILE__) + "/gen-rb"
|
|
23
|
+
require 'benchmark_service'
|
|
24
|
+
|
|
25
|
+
module Server
|
|
26
|
+
include Thrift
|
|
27
|
+
|
|
28
|
+
class BenchmarkHandler
|
|
29
|
+
# 1-based index into the fibonacci sequence
|
|
30
|
+
def fibonacci(n)
|
|
31
|
+
seq = [1, 1]
|
|
32
|
+
3.upto(n) do
|
|
33
|
+
seq << seq[-1] + seq[-2]
|
|
34
|
+
end
|
|
35
|
+
seq[n-1] # n is 1-based
|
|
36
|
+
end
|
|
37
|
+
end
|
|
38
|
+
|
|
39
|
+
def self.start_server(host, port, serverClass)
|
|
40
|
+
handler = BenchmarkHandler.new
|
|
41
|
+
processor = ThriftBenchmark::BenchmarkService::Processor.new(handler)
|
|
42
|
+
transport = ServerSocket.new(host, port)
|
|
43
|
+
transport_factory = FramedTransportFactory.new
|
|
44
|
+
args = [processor, transport, transport_factory, nil, 20]
|
|
45
|
+
if serverClass == NonblockingServer
|
|
46
|
+
logger = Logger.new(STDERR)
|
|
47
|
+
logger.level = Logger::WARN
|
|
48
|
+
args << logger
|
|
49
|
+
end
|
|
50
|
+
server = serverClass.new(*args)
|
|
51
|
+
@server_thread = Thread.new do
|
|
52
|
+
server.serve
|
|
53
|
+
end
|
|
54
|
+
@server = server
|
|
55
|
+
end
|
|
56
|
+
|
|
57
|
+
def self.shutdown
|
|
58
|
+
return if @server.nil?
|
|
59
|
+
if @server.respond_to? :shutdown
|
|
60
|
+
@server.shutdown
|
|
61
|
+
else
|
|
62
|
+
@server_thread.kill
|
|
63
|
+
end
|
|
64
|
+
end
|
|
65
|
+
end
|
|
66
|
+
|
|
67
|
+
def resolve_const(const)
|
|
68
|
+
const and const.split('::').inject(Object) { |k,c| k.const_get(c) }
|
|
69
|
+
end
|
|
70
|
+
|
|
71
|
+
host, port, serverklass = ARGV
|
|
72
|
+
|
|
73
|
+
Server.start_server(host, port.to_i, resolve_const(serverklass))
|
|
74
|
+
|
|
75
|
+
# let our host know that the interpreter has started
|
|
76
|
+
# ideally we'd wait until the server was serving, but we don't have a hook for that
|
|
77
|
+
Marshal.dump(:started, STDOUT)
|
|
78
|
+
STDOUT.flush
|
|
79
|
+
|
|
80
|
+
Marshal.load(STDIN) # wait until we're instructed to shut down
|
|
81
|
+
|
|
82
|
+
Server.shutdown
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
#
|
|
2
|
+
# Licensed to the Apache Software Foundation (ASF) under one
|
|
3
|
+
# or more contributor license agreements. See the NOTICE file
|
|
4
|
+
# distributed with this work for additional information
|
|
5
|
+
# regarding copyright ownership. The ASF licenses this file
|
|
6
|
+
# to you under the Apache License, Version 2.0 (the
|
|
7
|
+
# "License"); you may not use this file except in compliance
|
|
8
|
+
# with the License. You may obtain a copy of the License at
|
|
9
|
+
#
|
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
11
|
+
#
|
|
12
|
+
# Unless required by applicable law or agreed to in writing,
|
|
13
|
+
# software distributed under the License is distributed on an
|
|
14
|
+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
15
|
+
# KIND, either express or implied. See the License for the
|
|
16
|
+
# specific language governing permissions and limitations
|
|
17
|
+
# under the License.
|
|
18
|
+
#
|
|
19
|
+
|
|
20
|
+
$:.unshift File.dirname(__FILE__) + '/../lib'
|
|
21
|
+
require 'thrift'
|
|
22
|
+
$:.unshift File.dirname(__FILE__) + "/gen-rb"
|
|
23
|
+
require 'benchmark_service'
|
|
24
|
+
HOST = 'localhost'
|
|
25
|
+
PORT = 42587
|
|
26
|
+
|
|
27
|
+
class BenchmarkHandler
|
|
28
|
+
# 1-based index into the fibonacci sequence
|
|
29
|
+
def fibonacci(n)
|
|
30
|
+
seq = [1, 1]
|
|
31
|
+
3.upto(n) do
|
|
32
|
+
seq << seq[-1] + seq[-2]
|
|
33
|
+
end
|
|
34
|
+
seq[n-1] # n is 1-based
|
|
35
|
+
end
|
|
36
|
+
end
|
|
37
|
+
|
|
38
|
+
handler = BenchmarkHandler.new
|
|
39
|
+
processor = ThriftBenchmark::BenchmarkService::Processor.new(handler)
|
|
40
|
+
transport = Thrift::ServerSocket.new(HOST, PORT)
|
|
41
|
+
transport_factory = Thrift::FramedTransportFactory.new
|
|
42
|
+
logger = Logger.new(STDERR)
|
|
43
|
+
logger.level = Logger::WARN
|
|
44
|
+
Thrift::NonblockingServer.new(processor, transport, transport_factory, nil, 20, logger).serve
|