passenger 3.0.0 → 3.0.1
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of passenger might be problematic. Click here for more details.
- data/DEVELOPERS.TXT +9 -6
- data/NEWS +50 -0
- data/Rakefile +2 -1
- data/bin/passenger-install-apache2-module +4 -4
- data/bin/passenger-install-nginx-module +1 -1
- data/bin/passenger-make-enterprisey +1 -1
- data/build/agents.rb +26 -19
- data/build/apache2.rb +49 -46
- data/build/basics.rb +37 -13
- data/build/common_library.rb +134 -64
- data/build/config.rb +18 -11
- data/build/cplusplus_support.rb +4 -0
- data/build/cxx_tests.rb +26 -12
- data/build/documentation.rb +18 -11
- data/build/integration_tests.rb +18 -11
- data/build/misc.rb +18 -11
- data/build/nginx.rb +27 -19
- data/build/oxt_tests.rb +18 -11
- data/build/packaging.rb +45 -37
- data/build/rpm.rb +98 -0
- data/build/ruby_extension.rb +19 -13
- data/build/ruby_tests.rb +19 -12
- data/build/test_basics.rb +23 -11
- data/debian/README.Debian +15 -0
- data/debian/changelog +185 -0
- data/debian/control +47 -19
- data/debian/copyright +20 -0
- data/debian/libapache2-mod-passenger.install +1 -0
- data/debian/libapache2-mod-passenger.postinst +36 -0
- data/debian/libapache2-mod-passenger.prerm +15 -0
- data/debian/passenger-common.install +4 -0
- data/debian/passenger.conf +4 -0
- data/debian/passenger.load +1 -0
- data/debian/rules +37 -0
- data/debian/watch +3 -0
- data/{misc → dev}/copy_boost_headers.rb +3 -0
- data/{misc → dev}/find_owner_pipe_leaks.rb +0 -0
- data/{misc → dev}/render_error_pages.rb +0 -0
- data/doc/Users guide Apache.html +39 -1
- data/doc/Users guide Apache.txt +40 -0
- data/doc/Users guide Nginx.html +1 -1
- data/doc/Users guide Standalone.html +1 -1
- data/doc/cxxapi/Constants_8h_source.html +1 -1
- data/doc/cxxapi/DirectoryMapper_8h_source.html +6 -22
- data/doc/cxxapi/EventedClient_8h_source.html +572 -468
- data/doc/cxxapi/Exceptions_8h_source.html +142 -129
- data/doc/cxxapi/FileDescriptor_8h_source.html +263 -199
- data/doc/cxxapi/MessageChannel_8h_source.html +686 -770
- data/doc/cxxapi/MessageServer_8h_source.html +1 -1
- data/doc/cxxapi/PoolOptions_8h_source.html +79 -78
- data/doc/cxxapi/ResourceLocator_8h_source.html +105 -55
- data/doc/cxxapi/SafeLibev_8h_source.html +180 -0
- data/doc/cxxapi/ServerInstanceDir_8h_source.html +114 -110
- data/doc/cxxapi/Session_8h_source.html +1 -1
- data/doc/cxxapi/SpawnManager_8h_source.html +208 -208
- data/doc/cxxapi/StaticString_8h_source.html +258 -183
- data/doc/cxxapi/Utils_8h_source.html +71 -54
- data/doc/cxxapi/annotated.html +3 -0
- data/doc/cxxapi/classAgentWatcher.html +2 -2
- data/doc/cxxapi/classPassenger_1_1DirectoryMapper-members.html +0 -1
- data/doc/cxxapi/classPassenger_1_1DirectoryMapper.html +0 -27
- data/doc/cxxapi/classPassenger_1_1EventedClient-members.html +5 -0
- data/doc/cxxapi/classPassenger_1_1EventedClient.html +102 -7
- data/doc/cxxapi/classPassenger_1_1FileDescriptor-members.html +2 -1
- data/doc/cxxapi/classPassenger_1_1FileDescriptor.html +34 -8
- data/doc/cxxapi/classPassenger_1_1FileDescriptorPair-members.html +36 -0
- data/doc/cxxapi/classPassenger_1_1FileDescriptorPair.html +52 -0
- data/doc/cxxapi/classPassenger_1_1MessageChannel-members.html +0 -3
- data/doc/cxxapi/classPassenger_1_1MessageChannel.html +0 -120
- data/doc/cxxapi/classPassenger_1_1SafeLibev-members.html +36 -0
- data/doc/cxxapi/classPassenger_1_1SafeLibev.html +51 -0
- data/doc/cxxapi/classPassenger_1_1SpawnException-members.html +1 -0
- data/doc/cxxapi/classPassenger_1_1SpawnException.html +22 -0
- data/doc/cxxapi/classes.html +14 -14
- data/doc/cxxapi/files.html +2 -0
- data/doc/cxxapi/functions_0x63.html +6 -3
- data/doc/cxxapi/functions_0x64.html +9 -2
- data/doc/cxxapi/functions_0x67.html +6 -9
- data/doc/cxxapi/functions_0x69.html +3 -0
- data/doc/cxxapi/functions_0x77.html +8 -8
- data/doc/cxxapi/functions_eval.html +6 -0
- data/doc/cxxapi/functions_func.html +18 -17
- data/doc/cxxapi/functions_vars.html +8 -0
- data/doc/cxxapi/graph_legend.png +0 -0
- data/doc/cxxapi/group__Core.png +0 -0
- data/doc/cxxapi/group__Hooks.png +0 -0
- data/doc/cxxapi/hierarchy.html +3 -0
- data/doc/cxxapi/inherit__graph__14.map +1 -1
- data/doc/cxxapi/inherit__graph__14.md5 +1 -1
- data/doc/cxxapi/inherit__graph__14.png +0 -0
- data/doc/cxxapi/inherit__graph__15.map +1 -3
- data/doc/cxxapi/inherit__graph__15.md5 +1 -1
- data/doc/cxxapi/inherit__graph__15.png +0 -0
- data/doc/cxxapi/inherit__graph__16.map +3 -1
- data/doc/cxxapi/inherit__graph__16.md5 +1 -1
- data/doc/cxxapi/inherit__graph__16.png +0 -0
- data/doc/cxxapi/inherit__graph__17.map +1 -1
- data/doc/cxxapi/inherit__graph__17.md5 +1 -1
- data/doc/cxxapi/inherit__graph__17.png +0 -0
- data/doc/cxxapi/inherit__graph__18.map +1 -2
- data/doc/cxxapi/inherit__graph__18.md5 +1 -1
- data/doc/cxxapi/inherit__graph__18.png +0 -0
- data/doc/cxxapi/inherit__graph__19.map +2 -1
- data/doc/cxxapi/inherit__graph__19.md5 +1 -1
- data/doc/cxxapi/inherit__graph__19.png +0 -0
- data/doc/cxxapi/inherit__graph__20.map +1 -1
- data/doc/cxxapi/inherit__graph__20.md5 +1 -1
- data/doc/cxxapi/inherit__graph__20.png +0 -0
- data/doc/cxxapi/inherit__graph__21.map +1 -1
- data/doc/cxxapi/inherit__graph__21.md5 +1 -1
- data/doc/cxxapi/inherit__graph__21.png +0 -0
- data/doc/cxxapi/inherit__graph__22.map +1 -1
- data/doc/cxxapi/inherit__graph__22.md5 +1 -1
- data/doc/cxxapi/inherit__graph__22.png +0 -0
- data/doc/cxxapi/inherit__graph__23.map +1 -1
- data/doc/cxxapi/inherit__graph__23.md5 +1 -1
- data/doc/cxxapi/inherit__graph__23.png +0 -0
- data/doc/cxxapi/inherit__graph__24.map +1 -1
- data/doc/cxxapi/inherit__graph__24.md5 +1 -1
- data/doc/cxxapi/inherit__graph__24.png +0 -0
- data/doc/cxxapi/inherit__graph__25.map +1 -1
- data/doc/cxxapi/inherit__graph__25.md5 +1 -1
- data/doc/cxxapi/inherit__graph__25.png +0 -0
- data/doc/cxxapi/inherit__graph__26.map +1 -1
- data/doc/cxxapi/inherit__graph__26.md5 +1 -1
- data/doc/cxxapi/inherit__graph__26.png +0 -0
- data/doc/cxxapi/inherit__graph__27.map +1 -1
- data/doc/cxxapi/inherit__graph__27.md5 +1 -1
- data/doc/cxxapi/inherit__graph__27.png +0 -0
- data/doc/cxxapi/inherit__graph__28.map +1 -2
- data/doc/cxxapi/inherit__graph__28.md5 +1 -1
- data/doc/cxxapi/inherit__graph__28.png +0 -0
- data/doc/cxxapi/inherit__graph__29.map +1 -1
- data/doc/cxxapi/inherit__graph__29.md5 +1 -1
- data/doc/cxxapi/inherit__graph__29.png +0 -0
- data/doc/cxxapi/inherit__graph__30.map +1 -1
- data/doc/cxxapi/inherit__graph__30.md5 +1 -1
- data/doc/cxxapi/inherit__graph__30.png +0 -0
- data/doc/cxxapi/inherit__graph__31.map +2 -1
- data/doc/cxxapi/inherit__graph__31.md5 +1 -1
- data/doc/cxxapi/inherit__graph__31.png +0 -0
- data/doc/cxxapi/inherit__graph__32.map +1 -3
- data/doc/cxxapi/inherit__graph__32.md5 +1 -1
- data/doc/cxxapi/inherit__graph__32.png +0 -0
- data/doc/cxxapi/inherit__graph__33.map +1 -1
- data/doc/cxxapi/inherit__graph__33.md5 +1 -1
- data/doc/cxxapi/inherit__graph__33.png +0 -0
- data/doc/cxxapi/inherit__graph__34.map +1 -1
- data/doc/cxxapi/inherit__graph__34.md5 +1 -1
- data/doc/cxxapi/inherit__graph__34.png +0 -0
- data/doc/cxxapi/inherit__graph__35.map +3 -1
- data/doc/cxxapi/inherit__graph__35.md5 +1 -1
- data/doc/cxxapi/inherit__graph__35.png +0 -0
- data/doc/cxxapi/inherit__graph__36.map +1 -1
- data/doc/cxxapi/inherit__graph__36.md5 +1 -1
- data/doc/cxxapi/inherit__graph__36.png +0 -0
- data/doc/cxxapi/inherit__graph__37.map +1 -1
- data/doc/cxxapi/inherit__graph__37.md5 +1 -1
- data/doc/cxxapi/inherit__graph__37.png +0 -0
- data/doc/cxxapi/inherit__graph__38.map +3 -1
- data/doc/cxxapi/inherit__graph__38.md5 +1 -1
- data/doc/cxxapi/inherit__graph__38.png +0 -0
- data/doc/cxxapi/inherit__graph__39.map +3 -1
- data/doc/cxxapi/inherit__graph__39.md5 +1 -1
- data/doc/cxxapi/inherit__graph__39.png +0 -0
- data/doc/cxxapi/inherits.html +33 -24
- data/doc/cxxapi/namespacePassenger.html +52 -0
- data/doc/cxxapi/namespacemembers.html +6 -0
- data/doc/cxxapi/namespacemembers_func.html +6 -0
- data/doc/cxxapi/tree.html +8 -0
- data/ext/apache2/Configuration.cpp +30 -8
- data/ext/apache2/Configuration.hpp +15 -14
- data/ext/apache2/DirectoryMapper.h +0 -16
- data/ext/apache2/Hooks.cpp +30 -29
- data/ext/boost/algorithm/string/detail/case_conv.hpp +6 -6
- data/ext/boost/algorithm/string/detail/find_format.hpp +14 -4
- data/ext/boost/algorithm/string/detail/find_format_all.hpp +13 -3
- data/ext/boost/algorithm/string/detail/find_format_store.hpp +11 -0
- data/ext/boost/algorithm/string/erase.hpp +2 -2
- data/ext/boost/bind/placeholders.hpp +2 -2
- data/ext/boost/concept/detail/backward_compatibility.hpp +16 -0
- data/ext/boost/concept/detail/general.hpp +15 -6
- data/ext/boost/concept/detail/has_constraints.hpp +5 -3
- data/ext/boost/concept/usage.hpp +5 -4
- data/ext/boost/concept_check.hpp +10 -1
- data/ext/boost/config/abi/borland_prefix.hpp +1 -1
- data/ext/boost/config/auto_link.hpp +68 -21
- data/ext/boost/config/compiler/borland.hpp +11 -3
- data/ext/boost/config/compiler/clang.hpp +62 -0
- data/ext/boost/config/compiler/codegear.hpp +21 -7
- data/ext/boost/config/compiler/common_edg.hpp +4 -2
- data/ext/boost/config/compiler/digitalmars.hpp +1 -1
- data/ext/boost/config/compiler/gcc.hpp +46 -7
- data/ext/boost/config/compiler/gcc_xml.hpp +25 -0
- data/ext/boost/config/compiler/intel.hpp +23 -0
- data/ext/boost/config/compiler/kai.hpp +1 -1
- data/ext/boost/config/compiler/metrowerks.hpp +1 -1
- data/ext/boost/config/compiler/nvcc.hpp +86 -0
- data/ext/boost/config/compiler/pgi.hpp +18 -3
- data/ext/boost/config/compiler/sunpro_cc.hpp +19 -5
- data/ext/boost/config/compiler/vacpp.hpp +8 -0
- data/ext/boost/config/compiler/visualc.hpp +27 -11
- data/ext/boost/config/platform/cygwin.hpp +0 -3
- data/ext/boost/config/platform/symbian.hpp +94 -0
- data/ext/boost/config/platform/win32.hpp +8 -1
- data/ext/boost/config/select_compiler_config.hpp +10 -0
- data/ext/boost/config/select_platform_config.hpp +4 -0
- data/ext/boost/config/stdlib/dinkumware.hpp +11 -1
- data/ext/boost/config/stdlib/libcomo.hpp +1 -0
- data/ext/boost/config/stdlib/libstdcpp3.hpp +1 -0
- data/ext/boost/config/stdlib/modena.hpp +1 -0
- data/ext/boost/config/stdlib/msl.hpp +1 -0
- data/ext/boost/config/stdlib/roguewave.hpp +1 -0
- data/ext/boost/config/stdlib/sgi.hpp +1 -0
- data/ext/boost/config/stdlib/stlport.hpp +1 -0
- data/ext/boost/config/stdlib/vacpp.hpp +1 -0
- data/ext/boost/config/suffix.hpp +40 -2
- data/ext/boost/cstdint.hpp +36 -7
- data/ext/boost/date_time/gregorian/conversion.hpp +4 -2
- data/ext/boost/date_time/microsec_time_clock.hpp +7 -7
- data/ext/boost/date_time/posix_time/conversion.hpp +4 -2
- data/ext/boost/date_time/time_facet.hpp +43 -4
- data/ext/boost/detail/endian.hpp +5 -2
- data/ext/boost/detail/lcast_precision.hpp +2 -2
- data/ext/boost/detail/sp_typeinfo.hpp +1 -1
- data/ext/boost/detail/workaround.hpp +5 -0
- data/ext/boost/exception/detail/error_info_impl.hpp +3 -3
- data/ext/boost/exception/detail/exception_ptr.hpp +76 -135
- data/ext/boost/exception/detail/is_output_streamable.hpp +15 -2
- data/ext/boost/exception/detail/type_info.hpp +9 -5
- data/ext/boost/exception/diagnostic_information.hpp +5 -3
- data/ext/boost/exception/exception.hpp +60 -46
- data/ext/boost/exception/info.hpp +47 -14
- data/ext/boost/function/function_base.hpp +4 -4
- data/ext/boost/integer.hpp +4 -0
- data/ext/boost/integer_fwd.hpp +9 -3
- data/ext/boost/iterator/iterator_concepts.hpp +284 -0
- data/ext/boost/iterator/transform_iterator.hpp +0 -1
- data/ext/boost/make_shared.hpp +17 -0
- data/ext/boost/mpl/aux_/config/has_xxx.hpp +4 -3
- data/ext/boost/mpl/aux_/preprocessed/gcc/template_arity.hpp +2 -6
- data/ext/boost/mpl/aux_/template_arity.hpp +4 -4
- data/ext/boost/mpl/eval_if.hpp +3 -3
- data/ext/boost/mpl/has_xxx.hpp +369 -3
- data/ext/boost/optional/optional.hpp +3 -1
- data/ext/boost/optional/optional_fwd.hpp +1 -1
- data/ext/boost/preprocessor/repetition/enum_trailing_params.hpp +38 -0
- data/ext/boost/range/algorithm/equal.hpp +188 -0
- data/ext/boost/range/as_literal.hpp +15 -15
- data/ext/boost/range/concepts.hpp +331 -0
- data/ext/boost/range/const_iterator.hpp +7 -4
- data/ext/boost/range/detail/extract_optional_type.hpp +52 -0
- data/ext/boost/range/detail/implementation_help.hpp +7 -7
- data/ext/boost/range/detail/misc_concept.hpp +33 -0
- data/ext/boost/range/iterator.hpp +32 -32
- data/ext/boost/range/iterator_range.hpp +8 -651
- data/ext/boost/range/iterator_range_core.hpp +542 -0
- data/ext/boost/range/iterator_range_io.hpp +93 -0
- data/ext/boost/range/mutable_iterator.hpp +7 -4
- data/ext/boost/range/size.hpp +1 -1
- data/ext/boost/range/size_type.hpp +2 -1
- data/ext/boost/shared_array.hpp +19 -0
- data/ext/boost/smart_ptr/detail/sp_convertible.hpp +2 -2
- data/ext/boost/smart_ptr/detail/yield_k.hpp +1 -1
- data/ext/boost/smart_ptr/make_shared.hpp +508 -0
- data/ext/boost/smart_ptr/shared_array.hpp +147 -0
- data/ext/boost/src/pthread/thread.cpp +16 -21
- data/ext/boost/src/pthread/timeconv.inl +7 -4
- data/ext/boost/thread/barrier.hpp +2 -1
- data/ext/boost/thread/detail/config.hpp +7 -1
- data/ext/boost/thread/detail/platform.hpp +1 -1
- data/ext/boost/thread/detail/thread.hpp +62 -18
- data/ext/boost/thread/detail/thread_group.hpp +5 -2
- data/ext/boost/thread/detail/tss_hooks.hpp +8 -25
- data/ext/boost/thread/future.hpp +45 -34
- data/ext/boost/thread/locks.hpp +184 -55
- data/ext/boost/thread/pthread/condition_variable.hpp +7 -7
- data/ext/boost/thread/pthread/condition_variable_fwd.hpp +4 -2
- data/ext/boost/thread/pthread/mutex.hpp +29 -17
- data/ext/boost/thread/pthread/once.hpp +5 -0
- data/ext/boost/thread/pthread/recursive_mutex.hpp +97 -18
- data/ext/boost/thread/pthread/shared_mutex.hpp +1 -1
- data/ext/boost/thread/pthread/thread_heap_alloc.hpp +1 -1
- data/ext/boost/thread/tss.hpp +2 -0
- data/ext/boost/throw_exception.hpp +21 -5
- data/ext/boost/token_functions.hpp +111 -91
- data/ext/boost/type_traits/add_reference.hpp +19 -1
- data/ext/boost/type_traits/function_traits.hpp +2 -2
- data/ext/boost/type_traits/is_const.hpp +24 -5
- data/ext/boost/type_traits/is_convertible.hpp +1 -1
- data/ext/boost/type_traits/is_function.hpp +3 -0
- data/ext/boost/type_traits/is_lvalue_reference.hpp +118 -0
- data/ext/boost/type_traits/is_reference.hpp +8 -81
- data/ext/boost/type_traits/is_rvalue_reference.hpp +29 -0
- data/ext/boost/type_traits/is_same.hpp +2 -2
- data/ext/boost/type_traits/is_volatile.hpp +26 -7
- data/ext/boost/type_traits/remove_const.hpp +12 -0
- data/ext/boost/type_traits/remove_cv.hpp +23 -1
- data/ext/boost/type_traits/remove_reference.hpp +21 -1
- data/ext/boost/type_traits/type_with_alignment.hpp +10 -10
- data/ext/boost/units/detail/utility.hpp +104 -0
- data/ext/boost/utility/compare_pointees.hpp +1 -1
- data/ext/common/AgentsStarter.hpp +151 -161
- data/ext/common/ApplicationPool/Pool.h +16 -4
- data/ext/common/Constants.h +1 -1
- data/ext/common/EventedClient.h +130 -26
- data/ext/common/Exceptions.h +15 -2
- data/ext/common/FileDescriptor.h +76 -12
- data/ext/common/IniFile.h +488 -0
- data/ext/common/LoggingAgent/LoggingServer.h +2 -2
- data/ext/common/LoggingAgent/RemoteSender.h +15 -6
- data/ext/common/MessageChannel.h +17 -101
- data/ext/common/PoolOptions.h +1 -0
- data/ext/common/ResourceLocator.h +78 -28
- data/ext/common/SafeLibev.h +149 -0
- data/ext/common/ServerInstanceDir.h +11 -7
- data/ext/common/Session.h +1 -1
- data/ext/common/SpawnManager.h +14 -14
- data/ext/common/StaticString.h +75 -0
- data/ext/common/Utils.cpp +304 -12
- data/ext/common/Utils.h +17 -0
- data/ext/common/Utils/BufferedIO.h +196 -0
- data/ext/common/Utils/IOUtils.cpp +159 -0
- data/ext/common/Utils/IOUtils.h +118 -1
- data/ext/common/Utils/ProcessMetricsCollector.h +184 -56
- data/ext/common/Utils/StrIntUtils.cpp +45 -11
- data/ext/common/Utils/StrIntUtils.h +8 -5
- data/ext/common/Utils/Timer.h +22 -0
- data/ext/common/Utils/utf8.h +35 -0
- data/ext/common/Utils/utf8/checked.h +324 -0
- data/ext/common/Utils/utf8/core.h +359 -0
- data/ext/common/Utils/utf8/unchecked.h +229 -0
- data/ext/common/Watchdog.cpp +52 -85
- data/ext/libev/config.h +122 -0
- data/ext/nginx/Configuration.c +7 -1
- data/ext/nginx/HelperAgent.cpp +16 -18
- data/ext/nginx/config +6 -4
- data/ext/oxt/system_calls.cpp +10 -0
- data/ext/oxt/system_calls.hpp +2 -0
- data/lib/phusion_passenger.rb +6 -11
- data/lib/phusion_passenger/dependencies.rb +2 -0
- data/lib/phusion_passenger/packaging.rb +5 -5
- data/lib/phusion_passenger/platform_info.rb +88 -0
- data/lib/phusion_passenger/platform_info/binary_compatibility.rb +3 -17
- data/lib/phusion_passenger/platform_info/compiler.rb +14 -32
- data/lib/phusion_passenger/platform_info/curl.rb +6 -1
- data/lib/phusion_passenger/platform_info/operating_system.rb +107 -0
- data/lib/phusion_passenger/public_api.rb +2 -2
- data/lib/phusion_passenger/rails3_extensions/init.rb +5 -2
- data/lib/phusion_passenger/standalone/command.rb +6 -2
- data/lib/phusion_passenger/standalone/package_runtime_command.rb +2 -2
- data/lib/phusion_passenger/standalone/runtime_installer.rb +17 -5
- data/lib/phusion_passenger/standalone/start_command.rb +12 -12
- data/lib/phusion_passenger/standalone/stop_command.rb +3 -3
- data/lib/phusion_passenger/standalone/utils.rb +6 -2
- data/lib/phusion_passenger/templates/standalone/config.erb +37 -5
- data/lib/phusion_passenger/utils.rb +4 -7
- data/resources/mime.types +73 -0
- data/{misc → resources}/union_station_gateway.crt +0 -0
- data/test/cxx/BufferedIOTest.cpp +364 -0
- data/test/cxx/EventedClientTest.cpp +150 -13
- data/test/cxx/IOUtilsTest.cpp +399 -1
- data/test/cxx/MessageChannelTest.cpp +5 -120
- data/test/cxx/ProcessMetricsCollectorTest.cpp +121 -0
- data/test/cxx/StaticStringTest.cpp +134 -0
- data/test/cxx/UtilsTest.cpp +16 -46
- data/test/stub/rails_apps/2.3/mycook/public/dispatch.cgi +2 -2
- data/test/stub/rails_apps/2.3/mycook/public/dispatch.fcgi +1 -1
- data/test/stub/rails_apps/2.3/mycook/public/dispatch.rb +1 -1
- data/test/stub/rails_apps/3.0/empty/Gemfile.lock +73 -0
- data/test/support/allocate_memory.c +14 -0
- data/test/support/test_helper.rb +3 -0
- metadata +57 -174
- data/bin/passenger-stress-test +0 -345
- data/debian/postinst +0 -24
- data/doc/rdoc/classes/ConditionVariable.html +0 -215
- data/doc/rdoc/classes/Exception.html +0 -120
- data/doc/rdoc/classes/GC.html +0 -113
- data/doc/rdoc/classes/IO.html +0 -221
- data/doc/rdoc/classes/PhusionPassenger.html +0 -397
- data/doc/rdoc/classes/PhusionPassenger/AbstractInstaller.html +0 -180
- data/doc/rdoc/classes/PhusionPassenger/AbstractRequestHandler.html +0 -647
- data/doc/rdoc/classes/PhusionPassenger/AbstractServer.html +0 -654
- data/doc/rdoc/classes/PhusionPassenger/AbstractServer/InvalidPassword.html +0 -92
- data/doc/rdoc/classes/PhusionPassenger/AbstractServer/ServerAlreadyStarted.html +0 -97
- data/doc/rdoc/classes/PhusionPassenger/AbstractServer/ServerError.html +0 -96
- data/doc/rdoc/classes/PhusionPassenger/AbstractServer/ServerNotStarted.html +0 -97
- data/doc/rdoc/classes/PhusionPassenger/AbstractServer/UnknownMessage.html +0 -96
- data/doc/rdoc/classes/PhusionPassenger/AbstractServerCollection.html +0 -619
- data/doc/rdoc/classes/PhusionPassenger/AdminTools.html +0 -142
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/MemoryStats.html +0 -368
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/MemoryStats/Process.html +0 -231
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance.html +0 -588
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/CorruptedDirectoryError.html +0 -92
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/GenerationsAbsentError.html +0 -92
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/Group.html +0 -147
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/Process.html +0 -279
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/RoleDeniedError.html +0 -92
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/StaleDirectoryError.html +0 -92
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/Stats.html +0 -123
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/UnsupportedGenerationStructureVersionError.html +0 -92
- data/doc/rdoc/classes/PhusionPassenger/AnalyticsLogger.html +0 -341
- data/doc/rdoc/classes/PhusionPassenger/AnalyticsLogger/Log.html +0 -294
- data/doc/rdoc/classes/PhusionPassenger/AnalyticsLogger/SharedData.html +0 -199
- data/doc/rdoc/classes/PhusionPassenger/AppInitError.html +0 -155
- data/doc/rdoc/classes/PhusionPassenger/AppProcess.html +0 -367
- data/doc/rdoc/classes/PhusionPassenger/ClassicRails.html +0 -95
- data/doc/rdoc/classes/PhusionPassenger/ClassicRails/ApplicationSpawner.html +0 -351
- data/doc/rdoc/classes/PhusionPassenger/ClassicRails/ApplicationSpawner/Error.html +0 -98
- data/doc/rdoc/classes/PhusionPassenger/ClassicRails/CGIFixed.html +0 -200
- data/doc/rdoc/classes/PhusionPassenger/ClassicRails/FrameworkSpawner.html +0 -410
- data/doc/rdoc/classes/PhusionPassenger/ClassicRails/FrameworkSpawner/Error.html +0 -98
- data/doc/rdoc/classes/PhusionPassenger/ClassicRails/RequestHandler.html +0 -156
- data/doc/rdoc/classes/PhusionPassenger/ClassicRailsExtensions.html +0 -115
- data/doc/rdoc/classes/PhusionPassenger/ClassicRailsExtensions/AnalyticsLogging.html +0 -202
- data/doc/rdoc/classes/PhusionPassenger/ConsoleTextTemplate.html +0 -172
- data/doc/rdoc/classes/PhusionPassenger/DebugLogging.html +0 -273
- data/doc/rdoc/classes/PhusionPassenger/FrameworkInitError.html +0 -145
- data/doc/rdoc/classes/PhusionPassenger/HTMLTemplate.html +0 -162
- data/doc/rdoc/classes/PhusionPassenger/InitializationError.html +0 -141
- data/doc/rdoc/classes/PhusionPassenger/InvalidPath.html +0 -92
- data/doc/rdoc/classes/PhusionPassenger/MessageChannel.html +0 -673
- data/doc/rdoc/classes/PhusionPassenger/MessageChannel/InvalidHashError.html +0 -92
- data/doc/rdoc/classes/PhusionPassenger/MessageClient.html +0 -415
- data/doc/rdoc/classes/PhusionPassenger/NativeSupportLoader.html +0 -134
- data/doc/rdoc/classes/PhusionPassenger/Packaging.html +0 -129
- data/doc/rdoc/classes/PhusionPassenger/PlatformInfo.html +0 -1809
- data/doc/rdoc/classes/PhusionPassenger/Plugin.html +0 -237
- data/doc/rdoc/classes/PhusionPassenger/Rack.html +0 -91
- data/doc/rdoc/classes/PhusionPassenger/Rack/ApplicationSpawner.html +0 -312
- data/doc/rdoc/classes/PhusionPassenger/Rack/ApplicationSpawner/Error.html +0 -98
- data/doc/rdoc/classes/PhusionPassenger/Rack/RequestHandler.html +0 -218
- data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions.html +0 -114
- data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions/AnalyticsLogging.html +0 -256
- data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions/AnalyticsLogging/ACExtension.html +0 -139
- data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions/AnalyticsLogging/ASBenchmarkableExtension.html +0 -118
- data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions/AnalyticsLogging/ExceptionLogger.html +0 -135
- data/doc/rdoc/classes/PhusionPassenger/SpawnManager.html +0 -378
- data/doc/rdoc/classes/PhusionPassenger/Standalone.html +0 -111
- data/doc/rdoc/classes/PhusionPassenger/Standalone/AppFinder.html +0 -252
- data/doc/rdoc/classes/PhusionPassenger/Standalone/Command.html +0 -161
- data/doc/rdoc/classes/PhusionPassenger/Standalone/ConfigFile.html +0 -368
- data/doc/rdoc/classes/PhusionPassenger/Standalone/ConfigFile/DisallowedContextError.html +0 -132
- data/doc/rdoc/classes/PhusionPassenger/Standalone/HelpCommand.html +0 -151
- data/doc/rdoc/classes/PhusionPassenger/Standalone/Main.html +0 -189
- data/doc/rdoc/classes/PhusionPassenger/Standalone/PackageRuntimeCommand.html +0 -177
- data/doc/rdoc/classes/PhusionPassenger/Standalone/RuntimeInstaller.html +0 -341
- data/doc/rdoc/classes/PhusionPassenger/Standalone/StartCommand.html +0 -203
- data/doc/rdoc/classes/PhusionPassenger/Standalone/StatusCommand.html +0 -156
- data/doc/rdoc/classes/PhusionPassenger/Standalone/StopCommand.html +0 -168
- data/doc/rdoc/classes/PhusionPassenger/Standalone/Utils.html +0 -86
- data/doc/rdoc/classes/PhusionPassenger/Standalone/VersionCommand.html +0 -135
- data/doc/rdoc/classes/PhusionPassenger/UnknownError.html +0 -125
- data/doc/rdoc/classes/PhusionPassenger/Utils.html +0 -1550
- data/doc/rdoc/classes/PhusionPassenger/Utils/FileSystemWatcher.html +0 -204
- data/doc/rdoc/classes/PhusionPassenger/Utils/FileSystemWatcher/DirInfo.html +0 -171
- data/doc/rdoc/classes/PhusionPassenger/Utils/FileSystemWatcher/FileInfo.html +0 -140
- data/doc/rdoc/classes/PhusionPassenger/Utils/HostsFileParser.html +0 -260
- data/doc/rdoc/classes/PhusionPassenger/Utils/PseudoIO.html +0 -169
- data/doc/rdoc/classes/PhusionPassenger/Utils/RewindableInput.html +0 -265
- data/doc/rdoc/classes/PhusionPassenger/Utils/RewindableInput/Tempfile.html +0 -120
- data/doc/rdoc/classes/PhusionPassenger/Utils/UnseekableSocket.html +0 -561
- data/doc/rdoc/classes/PhusionPassenger/VersionNotFound.html +0 -140
- data/doc/rdoc/classes/PhusionPassenger/WSGI.html +0 -89
- data/doc/rdoc/classes/PhusionPassenger/WSGI/ApplicationSpawner.html +0 -182
- data/doc/rdoc/classes/Process.html +0 -115
- data/doc/rdoc/classes/Signal.html +0 -139
- data/doc/rdoc/created.rid +0 -1
- data/doc/rdoc/files/DEVELOPERS_TXT.html +0 -276
- data/doc/rdoc/files/README.html +0 -157
- data/doc/rdoc/files/lib/phusion_passenger/abstract_installer_rb.html +0 -130
- data/doc/rdoc/files/lib/phusion_passenger/abstract_request_handler_rb.html +0 -135
- data/doc/rdoc/files/lib/phusion_passenger/abstract_server_collection_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/abstract_server_rb.html +0 -128
- data/doc/rdoc/files/lib/phusion_passenger/admin_tools/memory_stats_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/admin_tools/server_instance_rb.html +0 -132
- data/doc/rdoc/files/lib/phusion_passenger/admin_tools_rb.html +0 -122
- data/doc/rdoc/files/lib/phusion_passenger/analytics_logger_rb.html +0 -129
- data/doc/rdoc/files/lib/phusion_passenger/app_process_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/classic_rails/application_spawner_rb.html +0 -141
- data/doc/rdoc/files/lib/phusion_passenger/classic_rails/cgi_fixed_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/classic_rails/framework_spawner_rb.html +0 -146
- data/doc/rdoc/files/lib/phusion_passenger/classic_rails/request_handler_rb.html +0 -125
- data/doc/rdoc/files/lib/phusion_passenger/classic_rails_extensions/init_rb.html +0 -132
- data/doc/rdoc/files/lib/phusion_passenger/console_text_template_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/constants_rb.html +0 -122
- data/doc/rdoc/files/lib/phusion_passenger/debug_logging_rb.html +0 -122
- data/doc/rdoc/files/lib/phusion_passenger/dependencies_rb.html +0 -147
- data/doc/rdoc/files/lib/phusion_passenger/exceptions_rb.html +0 -122
- data/doc/rdoc/files/lib/phusion_passenger/html_template_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/message_channel_rb.html +0 -120
- data/doc/rdoc/files/lib/phusion_passenger/message_client_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/native_support_rb.html +0 -132
- data/doc/rdoc/files/lib/phusion_passenger/packaging_rb.html +0 -122
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/apache_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/binary_compatibility_rb.html +0 -129
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/compiler_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/curl_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/documentation_tools_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/linux_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/operating_system_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/ruby_rb.html +0 -128
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/zlib_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/platform_info_rb.html +0 -122
- data/doc/rdoc/files/lib/phusion_passenger/plugin_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/public_api_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/rack/application_spawner_rb.html +0 -137
- data/doc/rdoc/files/lib/phusion_passenger/rack/request_handler_rb.html +0 -125
- data/doc/rdoc/files/lib/phusion_passenger/rails3_extensions/init_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/simple_benchmarking_rb.html +0 -122
- data/doc/rdoc/files/lib/phusion_passenger/spawn_manager_rb.html +0 -160
- data/doc/rdoc/files/lib/phusion_passenger/standalone/app_finder_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/standalone/command_rb.html +0 -135
- data/doc/rdoc/files/lib/phusion_passenger/standalone/config_file_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/standalone/help_command_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/standalone/main_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/standalone/package_runtime_command_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/standalone/runtime_installer_rb.html +0 -133
- data/doc/rdoc/files/lib/phusion_passenger/standalone/start_command_rb.html +0 -136
- data/doc/rdoc/files/lib/phusion_passenger/standalone/status_command_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/standalone/stop_command_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/standalone/utils_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/standalone/version_command_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/utils/file_system_watcher_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/utils/hosts_file_parser_rb.html +0 -120
- data/doc/rdoc/files/lib/phusion_passenger/utils/rewindable_input_rb.html +0 -100
- data/doc/rdoc/files/lib/phusion_passenger/utils/tmpdir_rb.html +0 -122
- data/doc/rdoc/files/lib/phusion_passenger/utils/unseekable_socket_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/utils_rb.html +0 -179
- data/doc/rdoc/files/lib/phusion_passenger/wsgi/application_spawner_rb.html +0 -132
- data/doc/rdoc/fr_class_index.html +0 -138
- data/doc/rdoc/fr_file_index.html +0 -108
- data/doc/rdoc/fr_method_index.html +0 -430
- data/doc/rdoc/index.html +0 -26
- data/doc/rdoc/rdoc-style.css +0 -187
- data/ext/apache2/LICENSE-CNRI.TXT +0 -79
- data/ext/common/Utils/BlockingScalar.h +0 -50
- data/ext/common/Utils/FileHandleGuard.h +0 -81
@@ -205,7 +205,7 @@ namespace tut {
|
|
205
205
|
|
206
206
|
TEST_METHOD(9) {
|
207
207
|
// readScalar() should be able to read messages constructed by writeScalar().
|
208
|
-
// This also tests
|
208
|
+
// This also tests readExact()/writeExact() because readScalar()/writeScalar() uses
|
209
209
|
// them internally.
|
210
210
|
writer.writeScalar("hello\n\r world!!!");
|
211
211
|
writer.writeScalar(" and this is a second message");
|
@@ -380,121 +380,6 @@ namespace tut {
|
|
380
380
|
ensure(!channel.connected());
|
381
381
|
}
|
382
382
|
|
383
|
-
TEST_METHOD(15) {
|
384
|
-
// waitUntilReadable() waits for the specified timeout if no data is readable.
|
385
|
-
unsigned long long timeout = 25;
|
386
|
-
ensure("No data is available", !reader.waitUntilReadable(&timeout));
|
387
|
-
ensure("The passed time is deducted from the timeout", timeout < 5);
|
388
|
-
}
|
389
|
-
|
390
|
-
TEST_METHOD(16) {
|
391
|
-
// waitUntilReadable() waits for less than the specified timeout if data
|
392
|
-
// is not available immediately but still available before the timeout.
|
393
|
-
TempThread thr(boost::bind(&writeDataAfterSomeTime, writer.filenum(), 35));
|
394
|
-
|
395
|
-
unsigned long long timeout = 1000;
|
396
|
-
ensure("Data is available", reader.waitUntilReadable(&timeout));
|
397
|
-
ensure("At least 35 msec passed.", timeout <= 1000 - 35);
|
398
|
-
ensure("At most 70 msec passed.", timeout >= 1000 - 70); // depends on system scheduler though
|
399
|
-
}
|
400
|
-
|
401
|
-
TEST_METHOD(17) {
|
402
|
-
// waitUntilReadable() returns immediately if timeout is 0.
|
403
|
-
unsigned long long timeout = 0;
|
404
|
-
ensure("No data is available", !reader.waitUntilReadable(&timeout));
|
405
|
-
ensure_equals("Timeout is not modified", timeout, 0u);
|
406
|
-
|
407
|
-
write(writer.filenum(), "hi", 2);
|
408
|
-
ensure("Data is available", reader.waitUntilReadable(&timeout));
|
409
|
-
ensure_equals("Timeout is not modified", timeout, 0u);
|
410
|
-
}
|
411
|
-
|
412
|
-
TEST_METHOD(18) {
|
413
|
-
// waitUntilReadable() returns immediately if there's data immediately available.
|
414
|
-
unsigned long long timeout = 100;
|
415
|
-
writer.writeRaw("hi", 2);
|
416
|
-
ensure("Data is available", reader.waitUntilReadable(&timeout));
|
417
|
-
ensure("Timeout is not modified", timeout >= 100 - 5);
|
418
|
-
}
|
419
|
-
|
420
|
-
TEST_METHOD(19) {
|
421
|
-
// readRaw() throws TimeoutException if no data is received within the timeout.
|
422
|
-
unsigned long long timeout = 50;
|
423
|
-
char buf;
|
424
|
-
try {
|
425
|
-
reader.readRaw(&buf, 1, &timeout);
|
426
|
-
fail("No TimeoutException thrown.");
|
427
|
-
} catch (const TimeoutException &) {
|
428
|
-
ensure("The passed time is deducted from timeout", timeout < 5);
|
429
|
-
}
|
430
|
-
}
|
431
|
-
|
432
|
-
TEST_METHOD(20) {
|
433
|
-
// readRaw() throws TimeoutException if not enough data is received within the timeout.
|
434
|
-
unsigned long long timeout = 20;
|
435
|
-
char buf[100];
|
436
|
-
|
437
|
-
TempThread thr(boost::bind(&writeDataSlowly, writer.filenum(), sizeof(buf), 1));
|
438
|
-
|
439
|
-
try {
|
440
|
-
reader.readRaw(&buf, sizeof(buf), &timeout);
|
441
|
-
fail("No TimeoutException thrown.");
|
442
|
-
} catch (const TimeoutException &) {
|
443
|
-
ensure("The passed time is deducted from timeout", timeout < 5);
|
444
|
-
}
|
445
|
-
}
|
446
|
-
|
447
|
-
TEST_METHOD(21) {
|
448
|
-
// readRaw() throws TimeException if timeout is 0 and no data is immediately available.
|
449
|
-
unsigned long long timeout = 0;
|
450
|
-
char buf;
|
451
|
-
try {
|
452
|
-
reader.readRaw(&buf, 1, &timeout);
|
453
|
-
fail("No TimeoutException thrown.");
|
454
|
-
} catch (const TimeoutException &) {
|
455
|
-
ensure_equals("Timeout unchanged", timeout, 0u);
|
456
|
-
}
|
457
|
-
}
|
458
|
-
|
459
|
-
TEST_METHOD(22) {
|
460
|
-
// readRaw() throws TimeoutException if timeout is 0 and not enough data is
|
461
|
-
// immediately available.
|
462
|
-
unsigned long long timeout = 0;
|
463
|
-
writer.writeRaw("hi", 2);
|
464
|
-
try {
|
465
|
-
char buf[100];
|
466
|
-
reader.readRaw(&buf, sizeof(buf), &timeout);
|
467
|
-
fail("No TimeoutException thrown.");
|
468
|
-
} catch (const TimeoutException &) {
|
469
|
-
ensure_equals("Timeout is unchanged", timeout, 0u);
|
470
|
-
}
|
471
|
-
}
|
472
|
-
|
473
|
-
TEST_METHOD(23) {
|
474
|
-
// readRaw() deducts the amount of time spent on waiting from the timeout variable.
|
475
|
-
unsigned long long timeout = 60;
|
476
|
-
char buf[3];
|
477
|
-
|
478
|
-
// Spawn a thread that writes 100 bytes per second, i.e. each byte takes 10 msec.
|
479
|
-
TempThread thr(boost::bind(&writeDataSlowly, writer.filenum(), 1000, 100));
|
480
|
-
|
481
|
-
// We read 3 bytes.
|
482
|
-
reader.readRaw(&buf, sizeof(buf), &timeout);
|
483
|
-
ensure("Should have taken at least 20 msec", timeout <= 60 - 20);
|
484
|
-
ensure("Should have taken at most 40 msec", timeout >= 60 - 40);
|
485
|
-
}
|
486
|
-
|
487
|
-
TEST_METHOD(24) {
|
488
|
-
// readRaw() does not wait and does not modify the timeout variable if there's
|
489
|
-
// immediately enough data available.
|
490
|
-
unsigned long long timeout = 100;
|
491
|
-
char buf[2];
|
492
|
-
|
493
|
-
writer.writeRaw("hi", 2);
|
494
|
-
reader.readRaw(&buf, 2, &timeout);
|
495
|
-
ensure_equals("Timeout not modified", timeout, 100u);
|
496
|
-
}
|
497
|
-
|
498
383
|
TEST_METHOD(25) {
|
499
384
|
// readScalar() doesn't throw SecurityException if maxSize is
|
500
385
|
// given but the available amount of data equals maxSize.
|
@@ -533,7 +418,7 @@ namespace tut {
|
|
533
418
|
// within the timeout.
|
534
419
|
unsigned long long timeout = 30;
|
535
420
|
string str;
|
536
|
-
writer.
|
421
|
+
writeExact(writer.filenum(), "xxx", 3); // A part of a random 32-bit integer header.
|
537
422
|
try {
|
538
423
|
reader.readScalar(str, 0, &timeout);
|
539
424
|
fail("TimeoutException expected");
|
@@ -612,7 +497,7 @@ namespace tut {
|
|
612
497
|
|
613
498
|
TEST_METHOD(33) {
|
614
499
|
// readUint32() returns false if EOF was reached prematurely.
|
615
|
-
writer.
|
500
|
+
writeExact(writer.filenum(), "x", 1);
|
616
501
|
writer.close();
|
617
502
|
unsigned int i;
|
618
503
|
ensure(!reader.readUint32(i));
|
@@ -634,7 +519,7 @@ namespace tut {
|
|
634
519
|
// readUint32() throws TimeoutException if not enough data was available within the timeout.
|
635
520
|
unsigned long long timeout = 30;
|
636
521
|
unsigned int i;
|
637
|
-
writer.
|
522
|
+
writeExact(writer.filenum(), "xx", 2);
|
638
523
|
try {
|
639
524
|
reader.readUint32(i, &timeout);
|
640
525
|
fail("TimeoutException expected");
|
@@ -661,7 +546,7 @@ namespace tut {
|
|
661
546
|
// data is immediately available.
|
662
547
|
unsigned long long timeout = 0;
|
663
548
|
unsigned int i;
|
664
|
-
writer.
|
549
|
+
writeExact(writer.filenum(), "xx", 2);
|
665
550
|
try {
|
666
551
|
reader.readUint32(i, &timeout);
|
667
552
|
fail("TimeoutException expected");
|
@@ -0,0 +1,121 @@
|
|
1
|
+
#include <sys/wait.h>
|
2
|
+
#include <signal.h>
|
3
|
+
#include <unistd.h>
|
4
|
+
#include <cstdio>
|
5
|
+
#include <cerrno>
|
6
|
+
#include "TestSupport.h"
|
7
|
+
#include "Utils/StrIntUtils.h"
|
8
|
+
#include "Utils/ProcessMetricsCollector.h"
|
9
|
+
|
10
|
+
using namespace Passenger;
|
11
|
+
|
12
|
+
namespace tut {
|
13
|
+
struct ProcessMetricsCollectorTest {
|
14
|
+
ProcessMetricsCollector collector;
|
15
|
+
pid_t child;
|
16
|
+
|
17
|
+
ProcessMetricsCollectorTest() {
|
18
|
+
child = -1;
|
19
|
+
}
|
20
|
+
|
21
|
+
~ProcessMetricsCollectorTest() {
|
22
|
+
if (child != -1) {
|
23
|
+
kill(child, SIGKILL);
|
24
|
+
waitpid(child, NULL, 0);
|
25
|
+
}
|
26
|
+
}
|
27
|
+
|
28
|
+
pid_t spawnChild(int memory) {
|
29
|
+
string memoryStr = toString(memory);
|
30
|
+
pid_t pid = fork();
|
31
|
+
if (pid == 0) {
|
32
|
+
execlp("support/allocate_memory",
|
33
|
+
"support/allocate_memory",
|
34
|
+
memoryStr.c_str(),
|
35
|
+
(char *) 0);
|
36
|
+
|
37
|
+
int e = errno;
|
38
|
+
fprintf(stderr, "Cannot execute support/allocate_memory: %s\n",
|
39
|
+
strerror(e));
|
40
|
+
fflush(stderr);
|
41
|
+
_exit(1);
|
42
|
+
} else {
|
43
|
+
return pid;
|
44
|
+
}
|
45
|
+
}
|
46
|
+
};
|
47
|
+
|
48
|
+
DEFINE_TEST_GROUP(ProcessMetricsCollectorTest);
|
49
|
+
|
50
|
+
TEST_METHOD(1) {
|
51
|
+
// It collects the metrics for the given PIDs.
|
52
|
+
collector.setPsOutput(
|
53
|
+
" PID PPID %CPU RSS VSZ PGID COMMAND\n"
|
54
|
+
" 1 0 0.0 1276 2456836 1 /sbin/launchd\n"
|
55
|
+
"34678 1265 95.2 4128 2437812 34677 /bin/bash -li\n"
|
56
|
+
);
|
57
|
+
vector<pid_t> pids;
|
58
|
+
pids.push_back(1);
|
59
|
+
pids.push_back(34678);
|
60
|
+
ProcessMetricMap result = collector.collect(pids);
|
61
|
+
|
62
|
+
ensure_equals(result.size(), 2u);
|
63
|
+
|
64
|
+
ensure_equals(result[1].pid, (pid_t) 1);
|
65
|
+
ensure_equals(result[1].ppid, (pid_t) 0);
|
66
|
+
ensure_equals(result[1].cpu, 0u);
|
67
|
+
ensure_equals(result[1].rss, 1276u);
|
68
|
+
ensure_equals(result[1].processGroupId, (pid_t) 1);
|
69
|
+
ensure_equals(result[1].command, "/sbin/launchd");
|
70
|
+
|
71
|
+
ensure_equals(result[34678].pid, (pid_t) 34678);
|
72
|
+
ensure_equals(result[34678].ppid, (pid_t) 1265);
|
73
|
+
ensure_equals(result[34678].cpu, 95u);
|
74
|
+
ensure_equals(result[34678].rss, 4128u);
|
75
|
+
ensure_equals(result[34678].processGroupId, (pid_t) 34677);
|
76
|
+
ensure_equals(result[34678].command, "/bin/bash -li");
|
77
|
+
}
|
78
|
+
|
79
|
+
TEST_METHOD(2) {
|
80
|
+
// It does not collect the metrics for PIDs that don't exist.
|
81
|
+
collector.setPsOutput(
|
82
|
+
" PID PPID %CPU RSS VSZ PGID COMMAND\n"
|
83
|
+
" 1 0 0.0 1276 2456836 1 /sbin/launchd\n"
|
84
|
+
);
|
85
|
+
vector<pid_t> pids;
|
86
|
+
pids.push_back(1);
|
87
|
+
pids.push_back(34678);
|
88
|
+
ProcessMetricMap result = collector.collect(pids);
|
89
|
+
|
90
|
+
ensure_equals(result.size(), 1u);
|
91
|
+
ensure(result.find(1) != result.end());
|
92
|
+
ensure(result.find(34678) == result.end());
|
93
|
+
}
|
94
|
+
|
95
|
+
TEST_METHOD(3) {
|
96
|
+
// Measuring real memory usage works.
|
97
|
+
ssize_t pss, privateDirty, swap;
|
98
|
+
child = spawnChild(50);
|
99
|
+
usleep(500000);
|
100
|
+
collector.measureRealMemory(child, pss, privateDirty, swap);
|
101
|
+
#ifdef __APPLE__
|
102
|
+
if (geteuid() == 0) {
|
103
|
+
ensure(pss > 50000 && pss < 60000);
|
104
|
+
ensure(privateDirty > 50000 && privateDirty < 60000);
|
105
|
+
ensure_equals(swap, (ssize_t) -1);
|
106
|
+
} else {
|
107
|
+
ensure_equals(pss, (ssize_t) -1);
|
108
|
+
ensure_equals(privateDirty, (ssize_t) -1);
|
109
|
+
ensure_equals(swap, (ssize_t) -1);
|
110
|
+
}
|
111
|
+
#elif defined(__linux__)
|
112
|
+
ensure("PSS is correct", (pss > 50000 && pss < 60000) || pss == -1);
|
113
|
+
ensure("Private dirty is correct", privateDirty > 50000 && privateDirty < 60000);
|
114
|
+
ensure("Swap is correct", swap < 10000);
|
115
|
+
#else
|
116
|
+
ensure((pss > 50000 && pss < 60000) || pss == -1);
|
117
|
+
ensure((privateDirty > 50000 && privateDirty < 60000) || privateDirty == -1);
|
118
|
+
ensure(swap < 10000 || swap == -1);
|
119
|
+
#endif
|
120
|
+
}
|
121
|
+
}
|
@@ -83,4 +83,138 @@ namespace tut {
|
|
83
83
|
string("hello world") < string("hello")
|
84
84
|
);
|
85
85
|
}
|
86
|
+
|
87
|
+
TEST_METHOD(4) {
|
88
|
+
// Test find(char)
|
89
|
+
ensure_equals("Assertion 1",
|
90
|
+
StaticString("").find('c'),
|
91
|
+
string::npos
|
92
|
+
);
|
93
|
+
ensure_equals("Assertion 2",
|
94
|
+
StaticString("hello world").find('c'),
|
95
|
+
string::npos
|
96
|
+
);
|
97
|
+
ensure_equals("Assertion 3",
|
98
|
+
StaticString("hello world").find('h'),
|
99
|
+
(string::size_type) 0
|
100
|
+
);
|
101
|
+
ensure_equals("Assertion 4",
|
102
|
+
StaticString("hello world").find('o'),
|
103
|
+
(string::size_type) 4
|
104
|
+
);
|
105
|
+
|
106
|
+
ensure_equals("Assertion 5",
|
107
|
+
StaticString("hello world").find('h', 1),
|
108
|
+
string::npos
|
109
|
+
);
|
110
|
+
ensure_equals("Assertion 6",
|
111
|
+
StaticString("hello world").find('o', 1),
|
112
|
+
(string::size_type) 4
|
113
|
+
);
|
114
|
+
ensure_equals("Assertion 7",
|
115
|
+
StaticString("hello world").find('o', 5),
|
116
|
+
(string::size_type) 7
|
117
|
+
);
|
118
|
+
|
119
|
+
ensure_equals("Assertion 8",
|
120
|
+
StaticString("hello world").find('h', 12),
|
121
|
+
string::npos
|
122
|
+
);
|
123
|
+
ensure_equals("Assertion 9",
|
124
|
+
StaticString("hello world").find('h', 20),
|
125
|
+
string::npos
|
126
|
+
);
|
127
|
+
}
|
128
|
+
|
129
|
+
TEST_METHOD(5) {
|
130
|
+
// Test find(str)
|
131
|
+
ensure_equals("Assertion 1",
|
132
|
+
StaticString("").find(""),
|
133
|
+
(string::size_type) 0
|
134
|
+
);
|
135
|
+
ensure_equals("Assertion 2",
|
136
|
+
StaticString("").find("c"),
|
137
|
+
string::npos
|
138
|
+
);
|
139
|
+
ensure_equals("Assertion 3",
|
140
|
+
StaticString("hello world").find("c"),
|
141
|
+
string::npos
|
142
|
+
);
|
143
|
+
ensure_equals("Assertion 4",
|
144
|
+
StaticString("hello world").find("h"),
|
145
|
+
(string::size_type) 0
|
146
|
+
);
|
147
|
+
ensure_equals("Assertion 5",
|
148
|
+
StaticString("hello world").find("o"),
|
149
|
+
(string::size_type) 4
|
150
|
+
);
|
151
|
+
ensure_equals("Assertion 6",
|
152
|
+
StaticString("hello world").find("ello"),
|
153
|
+
(string::size_type) 1
|
154
|
+
);
|
155
|
+
ensure_equals("Assertion 7",
|
156
|
+
StaticString("hello world").find("world"),
|
157
|
+
(string::size_type) 6
|
158
|
+
);
|
159
|
+
ensure_equals("Assertion 8",
|
160
|
+
StaticString("hello world").find("worldd"),
|
161
|
+
string::npos
|
162
|
+
);
|
163
|
+
ensure_equals("Assertion 9",
|
164
|
+
StaticString("hello world").find(""),
|
165
|
+
(string::size_type) 0
|
166
|
+
);
|
167
|
+
|
168
|
+
ensure_equals("Assertion 10",
|
169
|
+
StaticString("hello world").find("h", 1),
|
170
|
+
string::npos
|
171
|
+
);
|
172
|
+
ensure_equals("Assertion 11",
|
173
|
+
StaticString("hello hello").find("ll", 1),
|
174
|
+
(string::size_type) 2
|
175
|
+
);
|
176
|
+
ensure_equals("Assertion 12",
|
177
|
+
StaticString("hello hello").find("ll", 3),
|
178
|
+
(string::size_type) 8
|
179
|
+
);
|
180
|
+
|
181
|
+
ensure_equals("Assertion 13",
|
182
|
+
StaticString("hello world").find("he", 12),
|
183
|
+
string::npos
|
184
|
+
);
|
185
|
+
ensure_equals("Assertion 14",
|
186
|
+
StaticString("hello world").find("he", 20),
|
187
|
+
string::npos
|
188
|
+
);
|
189
|
+
}
|
190
|
+
|
191
|
+
TEST_METHOD(6) {
|
192
|
+
// Test substr()
|
193
|
+
ensure_equals("Assertion 1",
|
194
|
+
StaticString("hello world").substr(),
|
195
|
+
"hello world");
|
196
|
+
ensure_equals("Assertion 2",
|
197
|
+
StaticString("hello world").substr(1),
|
198
|
+
"ello world");
|
199
|
+
ensure_equals("Assertion 3",
|
200
|
+
StaticString("hello world").substr(4),
|
201
|
+
"o world");
|
202
|
+
ensure_equals("Assertion 4",
|
203
|
+
StaticString("hello world").substr(11),
|
204
|
+
"");
|
205
|
+
|
206
|
+
try {
|
207
|
+
StaticString("hello world").substr(12);
|
208
|
+
fail("out_of_range expected");
|
209
|
+
} catch (out_of_range &) {
|
210
|
+
// Success.
|
211
|
+
}
|
212
|
+
|
213
|
+
ensure_equals("Assertion 5",
|
214
|
+
StaticString("hello world").substr(2, 3),
|
215
|
+
"llo");
|
216
|
+
ensure_equals("Assertion 6",
|
217
|
+
StaticString("hello world").substr(6, 10),
|
218
|
+
"world");
|
219
|
+
}
|
86
220
|
}
|
data/test/cxx/UtilsTest.cpp
CHANGED
@@ -1,7 +1,6 @@
|
|
1
1
|
#include "TestSupport.h"
|
2
2
|
#include "Utils.h"
|
3
3
|
#include "Utils/StrIntUtils.h"
|
4
|
-
#include "Utils/IOUtils.h"
|
5
4
|
#include "Utils/MemZeroGuard.h"
|
6
5
|
#include <sys/types.h>
|
7
6
|
#include <sys/stat.h>
|
@@ -316,9 +315,9 @@ namespace tut {
|
|
316
315
|
stat("tmp.dir/foo", &buf);
|
317
316
|
stat("tmp.dir/foo/bar", &buf2);
|
318
317
|
ensure_equals(buf.st_mode, buf2.st_mode);
|
319
|
-
ensure_equals(buf.st_mode & 0xFFF,
|
320
|
-
S_IRUSR | S_IWUSR | S_IXUSR | S_ISUID |
|
321
|
-
S_IROTH | S_IXOTH);
|
318
|
+
ensure_equals((mode_t) (buf.st_mode & 0xFFF),
|
319
|
+
(mode_t) (S_IRUSR | S_IWUSR | S_IXUSR | S_ISUID |
|
320
|
+
S_IROTH | S_IXOTH));
|
322
321
|
}
|
323
322
|
|
324
323
|
TEST_METHOD(43) {
|
@@ -466,50 +465,9 @@ namespace tut {
|
|
466
465
|
ensure_equals(stringToLL(" -5abcdef1234"), -5ll);
|
467
466
|
}
|
468
467
|
|
469
|
-
/***** Test getSocketAddressType() *****/
|
470
|
-
|
471
|
-
TEST_METHOD(51) {
|
472
|
-
ensure_equals(getSocketAddressType(""), SAT_UNKNOWN);
|
473
|
-
ensure_equals(getSocketAddressType("/foo.socket"), SAT_UNKNOWN);
|
474
|
-
ensure_equals(getSocketAddressType("unix:"), SAT_UNKNOWN);
|
475
|
-
ensure_equals(getSocketAddressType("unix:/"), SAT_UNIX);
|
476
|
-
ensure_equals(getSocketAddressType("unix:/foo.socket"), SAT_UNIX);
|
477
|
-
ensure_equals(getSocketAddressType("tcp:"), SAT_UNKNOWN);
|
478
|
-
ensure_equals(getSocketAddressType("tcp://"), SAT_UNKNOWN);
|
479
|
-
// Doesn't check whether it contains port
|
480
|
-
ensure_equals(getSocketAddressType("tcp://127.0.0.1"), SAT_TCP);
|
481
|
-
ensure_equals(getSocketAddressType("tcp://127.0.0.1:80"), SAT_TCP);
|
482
|
-
}
|
483
|
-
|
484
|
-
TEST_METHOD(52) {
|
485
|
-
ensure_equals(parseUnixSocketAddress("unix:/foo.socket"), "/foo.socket");
|
486
|
-
try {
|
487
|
-
parseUnixSocketAddress("unix:");
|
488
|
-
fail("ArgumentException expected");
|
489
|
-
} catch (const ArgumentException &e) {
|
490
|
-
// Pass.
|
491
|
-
}
|
492
|
-
}
|
493
|
-
|
494
|
-
TEST_METHOD(53) {
|
495
|
-
string host;
|
496
|
-
unsigned short port;
|
497
|
-
|
498
|
-
parseTcpSocketAddress("tcp://127.0.0.1:80", host, port);
|
499
|
-
ensure_equals(host, "127.0.0.1");
|
500
|
-
ensure_equals(port, 80);
|
501
|
-
|
502
|
-
try {
|
503
|
-
parseTcpSocketAddress("tcp://", host, port);
|
504
|
-
fail("ArgumentException expected");
|
505
|
-
} catch (const ArgumentException &e) {
|
506
|
-
// Pass.
|
507
|
-
}
|
508
|
-
}
|
509
|
-
|
510
468
|
/***** Test cEscapeString() *****/
|
511
469
|
|
512
|
-
TEST_METHOD(
|
470
|
+
TEST_METHOD(51) {
|
513
471
|
ensure_equals(cEscapeString(""), "");
|
514
472
|
ensure_equals(cEscapeString("abcdXYZ123!?"), "abcdXYZ123!?");
|
515
473
|
ensure_equals(cEscapeString("foo\n"), "foo\\n");
|
@@ -518,4 +476,16 @@ namespace tut {
|
|
518
476
|
"\\x00\\x01\\x02\\x03\\x04\\x05\\x06\\x07\\x08\\t");
|
519
477
|
ensure_equals(cEscapeString("\xFF\xFE\t\xD0"), "\\xFF\\xFE\\t\\xD0");
|
520
478
|
}
|
479
|
+
|
480
|
+
/***** Test escapeHTML() *****/
|
481
|
+
|
482
|
+
TEST_METHOD(52) {
|
483
|
+
const char weird[] = "Weird \x01\x00 characters?";
|
484
|
+
ensure_equals(escapeHTML(""), "");
|
485
|
+
ensure_equals(escapeHTML("hello\n\r\t WORLD!"), "hello\n\r\t WORLD!");
|
486
|
+
ensure_equals(escapeHTML("<b>bold</b>"), "<b>bold</b>");
|
487
|
+
ensure_equals(escapeHTML(StaticString(weird, sizeof(weird) - 1)),
|
488
|
+
"Weird � characters?");
|
489
|
+
ensure_equals(escapeHTML("UTF-8: ☃ ☀; ☁ ☂\x01"), "UTF-8: ☃ ☀; ☁ ☂");
|
490
|
+
}
|
521
491
|
}
|