passenger 5.0.4 → 5.0.5

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.

Files changed (550) hide show
  1. checksums.yaml +8 -8
  2. checksums.yaml.gz.asc +7 -7
  3. data.tar.gz.asc +7 -7
  4. data/.editorconfig +10 -0
  5. data/CHANGELOG +21 -0
  6. data/build/agents.rb +2 -2
  7. data/build/apache2.rb +6 -5
  8. data/build/common_library.rb +22 -7
  9. data/build/cxx_tests.rb +0 -3
  10. data/build/misc.rb +1 -1
  11. data/dev/parse_file_descriptor_log +119 -0
  12. data/doc/CloudLicensingConfiguration.html +387 -0
  13. data/doc/Design and Architecture.html +2430 -0
  14. data/doc/Packaging.html +488 -0
  15. data/doc/Security of user switching support.html +1833 -0
  16. data/doc/ServerOptimizationGuide.html +659 -0
  17. data/doc/ServerOptimizationGuide.txt.md +8 -0
  18. data/doc/Users guide Apache.html +9116 -0
  19. data/doc/Users guide Apache.idmap.txt +6 -2
  20. data/doc/Users guide Apache.txt +26 -7
  21. data/doc/Users guide Nginx.html +9025 -0
  22. data/doc/Users guide Nginx.idmap.txt +7 -3
  23. data/doc/Users guide Nginx.txt +29 -6
  24. data/doc/Users guide Standalone.html +3983 -0
  25. data/doc/Users guide.html +1748 -0
  26. data/doc/users_guide_snippets/installation.txt +4 -4
  27. data/ext/apache2/Configuration.cpp +16 -5
  28. data/ext/apache2/Configuration.hpp +4 -2
  29. data/ext/apache2/Hooks.cpp +44 -19
  30. data/ext/boost/libs/thread/src/pthread/once.cpp +2 -0
  31. data/ext/boost/libs/thread/src/pthread/once_atomic.cpp +6 -0
  32. data/ext/common/AgentsStarter.h +3 -2
  33. data/ext/common/ApplicationPool2/DirectSpawner.h +14 -4
  34. data/ext/common/ApplicationPool2/DummySpawner.h +12 -7
  35. data/ext/common/ApplicationPool2/Implementation.cpp +1 -1
  36. data/ext/common/ApplicationPool2/Process.h +2 -1
  37. data/ext/common/ApplicationPool2/Session.h +6 -6
  38. data/ext/common/ApplicationPool2/SmartSpawner.h +19 -4
  39. data/ext/common/ApplicationPool2/Socket.h +59 -27
  40. data/ext/common/ApplicationPool2/Spawner.h +2 -2
  41. data/ext/common/BackgroundEventLoop.cpp +6 -1
  42. data/ext/common/Constants.h +1 -1
  43. data/ext/common/EventedClient.h +1 -1
  44. data/ext/common/EventedServer.h +2 -2
  45. data/ext/common/FileDescriptor.h +25 -6
  46. data/ext/common/Logging.cpp +107 -52
  47. data/ext/common/Logging.h +146 -19
  48. data/ext/common/MessageClient.h +2 -2
  49. data/ext/common/MessageServer.h +3 -2
  50. data/ext/common/RandomGenerator.h +8 -7
  51. data/ext/common/SafeLibev.h +5 -1
  52. data/ext/common/ServerKit/AcceptLoadBalancer.h +9 -4
  53. data/ext/common/ServerKit/FdSinkChannel.h +5 -2
  54. data/ext/common/ServerKit/FdSourceChannel.h +5 -2
  55. data/ext/common/ServerKit/FileBufferedChannel.h +2 -0
  56. data/ext/common/ServerKit/FileBufferedFdSinkChannel.h +7 -2
  57. data/ext/common/ServerKit/HttpServer.h +6 -0
  58. data/ext/common/ServerKit/Server.h +40 -3
  59. data/ext/common/StaticString.h +20 -0
  60. data/ext/common/UnionStation/Connection.h +3 -1
  61. data/ext/common/UnionStation/Core.h +6 -4
  62. data/ext/common/Utils.cpp +4 -3
  63. data/ext/common/Utils/DateParsing.h +19 -5
  64. data/ext/common/Utils/FastStringStream.h +183 -0
  65. data/ext/common/Utils/IOUtils.cpp +47 -28
  66. data/ext/common/Utils/IOUtils.h +56 -12
  67. data/ext/common/Utils/MessagePassing.h +3 -3
  68. data/ext/common/Utils/ProcessMetricsCollector.h +2 -2
  69. data/ext/common/Utils/ScopeGuard.h +16 -5
  70. data/ext/common/Utils/SpeedMeter.h +2 -2
  71. data/ext/common/Utils/StrIntUtils.cpp +6 -6
  72. data/ext/common/Utils/StrIntUtils.h +2 -1
  73. data/ext/common/agents/Base.cpp +56 -4
  74. data/ext/common/agents/Base.h +2 -1
  75. data/ext/common/agents/HelperAgent/AdminServer.h +122 -11
  76. data/ext/common/agents/HelperAgent/Main.cpp +16 -5
  77. data/ext/common/agents/HelperAgent/OptionParser.h +7 -1
  78. data/ext/common/agents/HelperAgent/RequestHandler.h +1 -1
  79. data/ext/common/agents/HelperAgent/RequestHandler/Hooks.cpp +10 -1
  80. data/ext/common/agents/HelperAgent/RequestHandler/Request.h +8 -0
  81. data/ext/common/agents/HelperAgent/RequestHandler/TurboCaching.h +4 -3
  82. data/ext/common/agents/LoggingAgent/AdminServer.h +57 -11
  83. data/ext/common/agents/LoggingAgent/LoggingServer.h +3 -3
  84. data/ext/common/agents/LoggingAgent/Main.cpp +11 -3
  85. data/ext/common/agents/Watchdog/AdminServer.h +53 -11
  86. data/ext/common/agents/Watchdog/AgentWatcher.cpp +3 -3
  87. data/ext/common/agents/Watchdog/Main.cpp +13 -6
  88. data/ext/libeio/ecb.h +1 -1
  89. data/ext/libev/ev.c +13 -1
  90. data/ext/libev/ev.h +3 -0
  91. data/ext/nginx/Configuration.c +28 -6
  92. data/ext/nginx/Configuration.h +2 -1
  93. data/ext/nginx/ngx_http_passenger_module.c +5 -4
  94. data/ext/oxt/dynamic_thread_group.hpp +38 -5
  95. data/lib/phusion_passenger.rb +1 -1
  96. data/lib/phusion_passenger/common_library.rb +9 -5
  97. data/lib/phusion_passenger/config/reopen_logs_command.rb +2 -2
  98. data/lib/phusion_passenger/packaging.rb +23 -37
  99. data/passenger.gemspec +21 -21
  100. metadata +4 -453
  101. metadata.gz.asc +7 -7
  102. data/.gitignore +0 -68
  103. data/.travis.yml +0 -16
  104. data/Gemfile +0 -17
  105. data/Gemfile.lock +0 -39
  106. data/Vagrantfile +0 -54
  107. data/debian.template/README.Debian +0 -15
  108. data/debian.template/changelog +0 -316
  109. data/debian.template/compat +0 -1
  110. data/debian.template/control.erb +0 -91
  111. data/debian.template/copyright +0 -385
  112. data/debian.template/libapache2-mod-passenger.install +0 -3
  113. data/debian.template/libapache2-mod-passenger.postinst +0 -36
  114. data/debian.template/libapache2-mod-passenger.prerm +0 -15
  115. data/debian.template/locations.ini.erb +0 -14
  116. data/debian.template/passenger-dev.install.erb +0 -3
  117. data/debian.template/passenger-doc.install.erb +0 -2
  118. data/debian.template/passenger.conf +0 -6
  119. data/debian.template/passenger.docs +0 -4
  120. data/debian.template/passenger.install.erb +0 -14
  121. data/debian.template/passenger.load +0 -3
  122. data/debian.template/passenger.manpages +0 -3
  123. data/debian.template/patches/series +0 -0
  124. data/debian.template/rules.erb +0 -76
  125. data/debian.template/source/format +0 -1
  126. data/ext/common/EventedBufferedInput.h +0 -458
  127. data/packaging/rpm/LICENSE.txt +0 -19
  128. data/packaging/rpm/Makefile +0 -13
  129. data/packaging/rpm/README.md +0 -41
  130. data/packaging/rpm/Vagrantfile +0 -38
  131. data/packaging/rpm/Vagrantfile.centos +0 -30
  132. data/packaging/rpm/build +0 -170
  133. data/packaging/rpm/create_project +0 -41
  134. data/packaging/rpm/git_update +0 -88
  135. data/packaging/rpm/image/Dockerfile +0 -37
  136. data/packaging/rpm/image/Gemfile +0 -3
  137. data/packaging/rpm/image/Gemfile.lock +0 -12
  138. data/packaging/rpm/image/RPM-GPG-KEY-amazon-ga +0 -19
  139. data/packaging/rpm/image/amazon2014-i386.cfg +0 -96
  140. data/packaging/rpm/image/amazon2014-x86_64.cfg +0 -96
  141. data/packaging/rpm/image/site-defaults.cfg +0 -168
  142. data/packaging/rpm/internal/build_tasks.rb +0 -238
  143. data/packaging/rpm/internal/dummygpg +0 -11
  144. data/packaging/rpm/internal/exec_build +0 -42
  145. data/packaging/rpm/internal/get_distro_arch +0 -14
  146. data/packaging/rpm/internal/get_distro_id +0 -10
  147. data/packaging/rpm/internal/git_update +0 -27
  148. data/packaging/rpm/internal/inituidgid +0 -17
  149. data/packaging/rpm/internal/my_init +0 -344
  150. data/packaging/rpm/internal/python27 +0 -3
  151. data/packaging/rpm/internal/repo_update +0 -46
  152. data/packaging/rpm/internal/setuser +0 -26
  153. data/packaging/rpm/internal/tracking_helper +0 -40
  154. data/packaging/rpm/jenkins_release +0 -99
  155. data/packaging/rpm/lib/build_tasks_support.rb +0 -402
  156. data/packaging/rpm/lib/preprocessor.rb +0 -341
  157. data/packaging/rpm/nginx_spec/404.html +0 -119
  158. data/packaging/rpm/nginx_spec/50x.html +0 -119
  159. data/packaging/rpm/nginx_spec/index.html +0 -116
  160. data/packaging/rpm/nginx_spec/nginx-auto-cc-gcc.patch +0 -13
  161. data/packaging/rpm/nginx_spec/nginx-logo.png +0 -0
  162. data/packaging/rpm/nginx_spec/nginx-upgrade +0 -13
  163. data/packaging/rpm/nginx_spec/nginx-upgrade.8 +0 -151
  164. data/packaging/rpm/nginx_spec/nginx.conf +0 -131
  165. data/packaging/rpm/nginx_spec/nginx.init +0 -144
  166. data/packaging/rpm/nginx_spec/nginx.logrotate +0 -13
  167. data/packaging/rpm/nginx_spec/nginx.service +0 -15
  168. data/packaging/rpm/nginx_spec/nginx.spec.template +0 -560
  169. data/packaging/rpm/nginx_spec/nginx.sysconfig +0 -4
  170. data/packaging/rpm/nginx_spec/passenger.conf +0 -9
  171. data/packaging/rpm/nginx_spec/poweredby.png +0 -0
  172. data/packaging/rpm/passenger_spec/apache-passenger.conf.in +0 -26
  173. data/packaging/rpm/passenger_spec/config.json +0 -30
  174. data/packaging/rpm/passenger_spec/passenger.logrotate +0 -7
  175. data/packaging/rpm/passenger_spec/passenger.spec.template +0 -478
  176. data/packaging/rpm/passenger_spec/passenger_dynamic_thread_group.patch +0 -16
  177. data/packaging/rpm/passenger_spec/passenger_tests_default_config_example.patch +0 -44
  178. data/packaging/rpm/passenger_spec/rubygem-passenger-4.0.18-GLIBC_HAVE_LONG_LONG.patch +0 -21
  179. data/packaging/rpm/repo_update +0 -114
  180. data/packaging/rpm/setup-system +0 -61
  181. data/packaging/rpm/shell +0 -10
  182. data/test/.rspec +0 -4
  183. data/test/config.json.example +0 -42
  184. data/test/config.json.rpm-automation +0 -15
  185. data/test/config.json.travis +0 -15
  186. data/test/config.json.vagrant +0 -30
  187. data/test/cxx/ApplicationPool2/DirectSpawnerTest.cpp +0 -124
  188. data/test/cxx/ApplicationPool2/OptionsTest.cpp +0 -30
  189. data/test/cxx/ApplicationPool2/PoolTest.cpp +0 -2062
  190. data/test/cxx/ApplicationPool2/ProcessTest.cpp +0 -130
  191. data/test/cxx/ApplicationPool2/SmartSpawnerTest.cpp +0 -243
  192. data/test/cxx/ApplicationPool2/SpawnerTestCases.cpp +0 -823
  193. data/test/cxx/BufferedIOTest.cpp +0 -364
  194. data/test/cxx/CachedFileStatTest.cpp +0 -402
  195. data/test/cxx/CxxTestMain.cpp +0 -181
  196. data/test/cxx/DataStructures/LStringTest.cpp +0 -275
  197. data/test/cxx/DataStructures/StringKeyTableTest.cpp +0 -199
  198. data/test/cxx/DateParsingTest.cpp +0 -75
  199. data/test/cxx/DechunkerTest.cpp +0 -250
  200. data/test/cxx/EventedBufferedInputTest.cpp +0 -758
  201. data/test/cxx/EventedClientTest.cpp +0 -523
  202. data/test/cxx/FileChangeCheckerTest.cpp +0 -331
  203. data/test/cxx/FileDescriptorTest.cpp +0 -69
  204. data/test/cxx/FilterSupportTest.cpp +0 -433
  205. data/test/cxx/IOUtilsTest.cpp +0 -861
  206. data/test/cxx/MemoryKit/MbufTest.cpp +0 -213
  207. data/test/cxx/MessageIOTest.cpp +0 -360
  208. data/test/cxx/MessagePassingTest.cpp +0 -81
  209. data/test/cxx/MessageReadersWritersTest.cpp +0 -576
  210. data/test/cxx/MessageServerTest.cpp +0 -393
  211. data/test/cxx/ProcessMetricsCollectorTest.cpp +0 -123
  212. data/test/cxx/RequestHandlerTest.cpp +0 -1463
  213. data/test/cxx/ResponseCacheTest.cpp +0 -322
  214. data/test/cxx/ServerKit/ChannelTest.cpp +0 -1467
  215. data/test/cxx/ServerKit/CookieUtilsTest.cpp +0 -274
  216. data/test/cxx/ServerKit/FileBufferedChannelTest.cpp +0 -992
  217. data/test/cxx/ServerKit/HeaderTableTest.cpp +0 -177
  218. data/test/cxx/ServerKit/HttpServerTest.cpp +0 -1580
  219. data/test/cxx/ServerKit/ServerTest.cpp +0 -408
  220. data/test/cxx/StaticStringTest.cpp +0 -220
  221. data/test/cxx/StringMapTest.cpp +0 -131
  222. data/test/cxx/SystemTimeTest.cpp +0 -37
  223. data/test/cxx/TemplateTest.cpp +0 -118
  224. data/test/cxx/TestSupport.cpp +0 -207
  225. data/test/cxx/TestSupport.h +0 -333
  226. data/test/cxx/UnionStationTest.cpp +0 -741
  227. data/test/cxx/Utils/StrIntUtilsTest.cpp +0 -39
  228. data/test/cxx/UtilsTest.cpp +0 -672
  229. data/test/cxx/VariantMapTest.cpp +0 -191
  230. data/test/gdbinit.example +0 -34
  231. data/test/integration_tests/apache2_tests.rb +0 -585
  232. data/test/integration_tests/downloaded_binaries_tests.rb +0 -185
  233. data/test/integration_tests/native_packaging_spec.rb +0 -368
  234. data/test/integration_tests/nginx_tests.rb +0 -402
  235. data/test/integration_tests/shared/example_webapp_tests.rb +0 -289
  236. data/test/integration_tests/source_packaging_test.rb +0 -201
  237. data/test/integration_tests/spec_helper.rb +0 -22
  238. data/test/integration_tests/standalone_tests.rb +0 -392
  239. data/test/node/line_reader_spec.js +0 -338
  240. data/test/node/spec_helper.js +0 -65
  241. data/test/oxt/backtrace_test.cpp +0 -88
  242. data/test/oxt/counter.hpp +0 -55
  243. data/test/oxt/dynamic_thread_group_test.cpp +0 -131
  244. data/test/oxt/oxt_test_main.cpp +0 -27
  245. data/test/oxt/spin_lock_test.cpp +0 -59
  246. data/test/oxt/syscall_interruption_test.cpp +0 -39
  247. data/test/ruby/debug_logging_spec.rb +0 -145
  248. data/test/ruby/message_channel_spec.rb +0 -196
  249. data/test/ruby/rack/loader_spec.rb +0 -42
  250. data/test/ruby/rack/preloader_spec.rb +0 -48
  251. data/test/ruby/rails3.0/loader_spec.rb +0 -26
  252. data/test/ruby/rails3.0/preloader_spec.rb +0 -32
  253. data/test/ruby/rails3.1/loader_spec.rb +0 -26
  254. data/test/ruby/rails3.1/preloader_spec.rb +0 -32
  255. data/test/ruby/rails3.2/loader_spec.rb +0 -26
  256. data/test/ruby/rails3.2/preloader_spec.rb +0 -32
  257. data/test/ruby/rails4.0/loader_spec.rb +0 -28
  258. data/test/ruby/rails4.0/preloader_spec.rb +0 -34
  259. data/test/ruby/rails4.1/loader_spec.rb +0 -28
  260. data/test/ruby/rails4.1/preloader_spec.rb +0 -34
  261. data/test/ruby/request_handler_spec.rb +0 -747
  262. data/test/ruby/shared/loader_sharedspec.rb +0 -247
  263. data/test/ruby/shared/rails/union_station_extensions_sharedspec.rb +0 -357
  264. data/test/ruby/shared/ruby_loader_sharedspec.rb +0 -55
  265. data/test/ruby/spec_helper.rb +0 -114
  266. data/test/ruby/standalone/runtime_installer_spec.rb +0 -402
  267. data/test/ruby/union_station_spec.rb +0 -288
  268. data/test/ruby/utils/file_system_watcher_spec.rb +0 -229
  269. data/test/ruby/utils/hosts_file_parser.rb +0 -258
  270. data/test/ruby/utils/tee_input_spec.rb +0 -235
  271. data/test/ruby/utils/unseekable_socket_spec.rb +0 -66
  272. data/test/ruby/utils_spec.rb +0 -41
  273. data/test/stub/apache2/httpd.conf.erb +0 -122
  274. data/test/stub/apache2/mime.types +0 -748
  275. data/test/stub/garbage1.dat +0 -0
  276. data/test/stub/garbage2.dat +0 -0
  277. data/test/stub/garbage3.dat +0 -0
  278. data/test/stub/http_request.yml +0 -23
  279. data/test/stub/index.html +0 -1
  280. data/test/stub/nginx/koi-utf +0 -109
  281. data/test/stub/nginx/koi-win +0 -103
  282. data/test/stub/nginx/mime.types +0 -70
  283. data/test/stub/nginx/nginx.conf.erb +0 -70
  284. data/test/stub/nginx/win-utf +0 -126
  285. data/test/stub/node/app.js +0 -133
  286. data/test/stub/node/public/.gitignore +0 -0
  287. data/test/stub/node/tmp/.gitignore +0 -0
  288. data/test/stub/rack/config.ru +0 -95
  289. data/test/stub/rack/library.rb +0 -16
  290. data/test/stub/rack/public/.gitignore +0 -0
  291. data/test/stub/rack/start.rb +0 -52
  292. data/test/stub/rack/tmp/.gitignore +0 -0
  293. data/test/stub/rails3.0/.gitignore +0 -4
  294. data/test/stub/rails3.0/Gemfile +0 -22
  295. data/test/stub/rails3.0/Gemfile.lock +0 -80
  296. data/test/stub/rails3.0/Rakefile +0 -10
  297. data/test/stub/rails3.0/app/controllers/application_controller.rb +0 -4
  298. data/test/stub/rails3.0/app/helpers/application_helper.rb +0 -2
  299. data/test/stub/rails3.0/app/views/layouts/application.html.erb +0 -14
  300. data/test/stub/rails3.0/config.ru +0 -4
  301. data/test/stub/rails3.0/config/application.rb +0 -48
  302. data/test/stub/rails3.0/config/boot.rb +0 -13
  303. data/test/stub/rails3.0/config/database.yml +0 -22
  304. data/test/stub/rails3.0/config/environment.rb +0 -5
  305. data/test/stub/rails3.0/config/environments/development.rb +0 -19
  306. data/test/stub/rails3.0/config/environments/production.rb +0 -48
  307. data/test/stub/rails3.0/config/environments/test.rb +0 -32
  308. data/test/stub/rails3.0/config/initializers/backtrace_silencers.rb +0 -7
  309. data/test/stub/rails3.0/config/initializers/inflections.rb +0 -10
  310. data/test/stub/rails3.0/config/initializers/mime_types.rb +0 -5
  311. data/test/stub/rails3.0/config/initializers/passenger.rb +0 -2
  312. data/test/stub/rails3.0/config/initializers/secret_token.rb +0 -7
  313. data/test/stub/rails3.0/config/initializers/session_store.rb +0 -8
  314. data/test/stub/rails3.0/config/locales/en.yml +0 -5
  315. data/test/stub/rails3.0/config/routes.rb +0 -58
  316. data/test/stub/rails3.0/db/seeds.rb +0 -7
  317. data/test/stub/rails3.0/doc/README_FOR_APP +0 -2
  318. data/test/stub/rails3.0/lib/tasks/.gitkeep +0 -0
  319. data/test/stub/rails3.0/log/.gitignore +0 -0
  320. data/test/stub/rails3.0/public/404.html +0 -26
  321. data/test/stub/rails3.0/public/422.html +0 -26
  322. data/test/stub/rails3.0/public/500.html +0 -26
  323. data/test/stub/rails3.0/public/favicon.ico +0 -0
  324. data/test/stub/rails3.0/public/index.html +0 -279
  325. data/test/stub/rails3.0/public/robots.txt +0 -5
  326. data/test/stub/rails3.0/public/stylesheets/.gitkeep +0 -0
  327. data/test/stub/rails3.0/script/rails +0 -9
  328. data/test/stub/rails3.0/test/performance/browsing_test.rb +0 -9
  329. data/test/stub/rails3.0/test/test_helper.rb +0 -13
  330. data/test/stub/rails3.0/vendor/plugins/.gitkeep +0 -0
  331. data/test/stub/rails3.1/.gitignore +0 -15
  332. data/test/stub/rails3.1/Gemfile +0 -37
  333. data/test/stub/rails3.1/Gemfile.lock +0 -115
  334. data/test/stub/rails3.1/README +0 -261
  335. data/test/stub/rails3.1/Rakefile +0 -7
  336. data/test/stub/rails3.1/app/assets/images/rails.png +0 -0
  337. data/test/stub/rails3.1/app/assets/stylesheets/application.css +0 -7
  338. data/test/stub/rails3.1/app/controllers/application_controller.rb +0 -3
  339. data/test/stub/rails3.1/app/helpers/application_helper.rb +0 -2
  340. data/test/stub/rails3.1/app/mailers/.gitkeep +0 -0
  341. data/test/stub/rails3.1/app/models/.gitkeep +0 -0
  342. data/test/stub/rails3.1/app/views/layouts/application.html.erb +0 -14
  343. data/test/stub/rails3.1/config.ru +0 -4
  344. data/test/stub/rails3.1/config/application.rb +0 -48
  345. data/test/stub/rails3.1/config/boot.rb +0 -6
  346. data/test/stub/rails3.1/config/database.yml +0 -25
  347. data/test/stub/rails3.1/config/environment.rb +0 -5
  348. data/test/stub/rails3.1/config/environments/development.rb +0 -30
  349. data/test/stub/rails3.1/config/environments/production.rb +0 -60
  350. data/test/stub/rails3.1/config/environments/test.rb +0 -39
  351. data/test/stub/rails3.1/config/initializers/backtrace_silencers.rb +0 -7
  352. data/test/stub/rails3.1/config/initializers/inflections.rb +0 -10
  353. data/test/stub/rails3.1/config/initializers/mime_types.rb +0 -5
  354. data/test/stub/rails3.1/config/initializers/passenger.rb +0 -2
  355. data/test/stub/rails3.1/config/initializers/secret_token.rb +0 -7
  356. data/test/stub/rails3.1/config/initializers/session_store.rb +0 -8
  357. data/test/stub/rails3.1/config/initializers/wrap_parameters.rb +0 -14
  358. data/test/stub/rails3.1/config/locales/en.yml +0 -5
  359. data/test/stub/rails3.1/config/routes.rb +0 -58
  360. data/test/stub/rails3.1/db/seeds.rb +0 -7
  361. data/test/stub/rails3.1/doc/README_FOR_APP +0 -2
  362. data/test/stub/rails3.1/lib/assets/.gitkeep +0 -0
  363. data/test/stub/rails3.1/lib/tasks/.gitkeep +0 -0
  364. data/test/stub/rails3.1/log/.gitkeep +0 -0
  365. data/test/stub/rails3.1/public/404.html +0 -26
  366. data/test/stub/rails3.1/public/422.html +0 -26
  367. data/test/stub/rails3.1/public/500.html +0 -26
  368. data/test/stub/rails3.1/public/favicon.ico +0 -0
  369. data/test/stub/rails3.1/public/index.html +0 -241
  370. data/test/stub/rails3.1/public/robots.txt +0 -5
  371. data/test/stub/rails3.1/script/rails +0 -6
  372. data/test/stub/rails3.1/test/fixtures/.gitkeep +0 -0
  373. data/test/stub/rails3.1/test/functional/.gitkeep +0 -0
  374. data/test/stub/rails3.1/test/integration/.gitkeep +0 -0
  375. data/test/stub/rails3.1/test/performance/browsing_test.rb +0 -12
  376. data/test/stub/rails3.1/test/test_helper.rb +0 -13
  377. data/test/stub/rails3.1/test/unit/.gitkeep +0 -0
  378. data/test/stub/rails3.1/vendor/assets/stylesheets/.gitkeep +0 -0
  379. data/test/stub/rails3.1/vendor/plugins/.gitkeep +0 -0
  380. data/test/stub/rails3.2/.gitignore +0 -15
  381. data/test/stub/rails3.2/Gemfile +0 -39
  382. data/test/stub/rails3.2/Gemfile.lock +0 -113
  383. data/test/stub/rails3.2/Rakefile +0 -7
  384. data/test/stub/rails3.2/app/assets/images/rails.png +0 -0
  385. data/test/stub/rails3.2/app/assets/stylesheets/application.css +0 -13
  386. data/test/stub/rails3.2/app/controllers/application_controller.rb +0 -3
  387. data/test/stub/rails3.2/app/helpers/application_helper.rb +0 -2
  388. data/test/stub/rails3.2/app/mailers/.gitkeep +0 -0
  389. data/test/stub/rails3.2/app/models/.gitkeep +0 -0
  390. data/test/stub/rails3.2/app/views/layouts/application.html.erb +0 -14
  391. data/test/stub/rails3.2/config.ru +0 -4
  392. data/test/stub/rails3.2/config/application.rb +0 -62
  393. data/test/stub/rails3.2/config/boot.rb +0 -6
  394. data/test/stub/rails3.2/config/database.yml +0 -25
  395. data/test/stub/rails3.2/config/environment.rb +0 -5
  396. data/test/stub/rails3.2/config/environments/development.rb +0 -37
  397. data/test/stub/rails3.2/config/environments/production.rb +0 -67
  398. data/test/stub/rails3.2/config/environments/test.rb +0 -37
  399. data/test/stub/rails3.2/config/initializers/backtrace_silencers.rb +0 -7
  400. data/test/stub/rails3.2/config/initializers/inflections.rb +0 -15
  401. data/test/stub/rails3.2/config/initializers/mime_types.rb +0 -5
  402. data/test/stub/rails3.2/config/initializers/passenger.rb +0 -2
  403. data/test/stub/rails3.2/config/initializers/secret_token.rb +0 -7
  404. data/test/stub/rails3.2/config/initializers/session_store.rb +0 -8
  405. data/test/stub/rails3.2/config/initializers/wrap_parameters.rb +0 -14
  406. data/test/stub/rails3.2/config/locales/en.yml +0 -5
  407. data/test/stub/rails3.2/config/routes.rb +0 -58
  408. data/test/stub/rails3.2/db/seeds.rb +0 -7
  409. data/test/stub/rails3.2/doc/README_FOR_APP +0 -2
  410. data/test/stub/rails3.2/lib/assets/.gitkeep +0 -0
  411. data/test/stub/rails3.2/lib/tasks/.gitkeep +0 -0
  412. data/test/stub/rails3.2/log/.gitkeep +0 -0
  413. data/test/stub/rails3.2/public/404.html +0 -26
  414. data/test/stub/rails3.2/public/422.html +0 -26
  415. data/test/stub/rails3.2/public/500.html +0 -25
  416. data/test/stub/rails3.2/public/favicon.ico +0 -0
  417. data/test/stub/rails3.2/public/index.html +0 -241
  418. data/test/stub/rails3.2/public/robots.txt +0 -5
  419. data/test/stub/rails3.2/script/rails +0 -6
  420. data/test/stub/rails3.2/test/fixtures/.gitkeep +0 -0
  421. data/test/stub/rails3.2/test/functional/.gitkeep +0 -0
  422. data/test/stub/rails3.2/test/integration/.gitkeep +0 -0
  423. data/test/stub/rails3.2/test/performance/browsing_test.rb +0 -12
  424. data/test/stub/rails3.2/test/test_helper.rb +0 -13
  425. data/test/stub/rails3.2/test/unit/.gitkeep +0 -0
  426. data/test/stub/rails3.2/vendor/assets/stylesheets/.gitkeep +0 -0
  427. data/test/stub/rails3.2/vendor/plugins/.gitkeep +0 -0
  428. data/test/stub/rails4.0/.gitignore +0 -16
  429. data/test/stub/rails4.0/Gemfile +0 -45
  430. data/test/stub/rails4.0/Gemfile.lock +0 -126
  431. data/test/stub/rails4.0/README.rdoc +0 -28
  432. data/test/stub/rails4.0/Rakefile +0 -6
  433. data/test/stub/rails4.0/app/assets/images/.keep +0 -0
  434. data/test/stub/rails4.0/app/assets/javascripts/application.js +0 -16
  435. data/test/stub/rails4.0/app/assets/stylesheets/application.css +0 -13
  436. data/test/stub/rails4.0/app/controllers/application_controller.rb +0 -5
  437. data/test/stub/rails4.0/app/controllers/concerns/.keep +0 -0
  438. data/test/stub/rails4.0/app/helpers/application_helper.rb +0 -2
  439. data/test/stub/rails4.0/app/mailers/.keep +0 -0
  440. data/test/stub/rails4.0/app/models/.keep +0 -0
  441. data/test/stub/rails4.0/app/models/concerns/.keep +0 -0
  442. data/test/stub/rails4.0/app/views/layouts/application.html.erb +0 -14
  443. data/test/stub/rails4.0/bin/bundle +0 -3
  444. data/test/stub/rails4.0/bin/rails +0 -4
  445. data/test/stub/rails4.0/bin/rake +0 -4
  446. data/test/stub/rails4.0/config.ru +0 -4
  447. data/test/stub/rails4.0/config/application.rb +0 -23
  448. data/test/stub/rails4.0/config/boot.rb +0 -4
  449. data/test/stub/rails4.0/config/database.yml +0 -25
  450. data/test/stub/rails4.0/config/environment.rb +0 -5
  451. data/test/stub/rails4.0/config/environments/development.rb +0 -29
  452. data/test/stub/rails4.0/config/environments/production.rb +0 -80
  453. data/test/stub/rails4.0/config/environments/test.rb +0 -36
  454. data/test/stub/rails4.0/config/initializers/backtrace_silencers.rb +0 -7
  455. data/test/stub/rails4.0/config/initializers/filter_parameter_logging.rb +0 -4
  456. data/test/stub/rails4.0/config/initializers/inflections.rb +0 -16
  457. data/test/stub/rails4.0/config/initializers/mime_types.rb +0 -5
  458. data/test/stub/rails4.0/config/initializers/passenger.rb +0 -2
  459. data/test/stub/rails4.0/config/initializers/secret_token.rb +0 -12
  460. data/test/stub/rails4.0/config/initializers/session_store.rb +0 -3
  461. data/test/stub/rails4.0/config/initializers/wrap_parameters.rb +0 -14
  462. data/test/stub/rails4.0/config/locales/en.yml +0 -23
  463. data/test/stub/rails4.0/config/routes.rb +0 -57
  464. data/test/stub/rails4.0/db/seeds.rb +0 -7
  465. data/test/stub/rails4.0/lib/assets/.keep +0 -0
  466. data/test/stub/rails4.0/lib/tasks/.keep +0 -0
  467. data/test/stub/rails4.0/log/.keep +0 -0
  468. data/test/stub/rails4.0/public/404.html +0 -58
  469. data/test/stub/rails4.0/public/422.html +0 -58
  470. data/test/stub/rails4.0/public/500.html +0 -57
  471. data/test/stub/rails4.0/public/favicon.ico +0 -0
  472. data/test/stub/rails4.0/public/robots.txt +0 -5
  473. data/test/stub/rails4.0/test/controllers/.keep +0 -0
  474. data/test/stub/rails4.0/test/fixtures/.keep +0 -0
  475. data/test/stub/rails4.0/test/helpers/.keep +0 -0
  476. data/test/stub/rails4.0/test/integration/.keep +0 -0
  477. data/test/stub/rails4.0/test/mailers/.keep +0 -0
  478. data/test/stub/rails4.0/test/models/.keep +0 -0
  479. data/test/stub/rails4.0/test/test_helper.rb +0 -15
  480. data/test/stub/rails4.0/vendor/assets/javascripts/.keep +0 -0
  481. data/test/stub/rails4.0/vendor/assets/stylesheets/.keep +0 -0
  482. data/test/stub/rails4.1/.gitignore +0 -16
  483. data/test/stub/rails4.1/Gemfile +0 -45
  484. data/test/stub/rails4.1/Gemfile.lock +0 -129
  485. data/test/stub/rails4.1/README.rdoc +0 -28
  486. data/test/stub/rails4.1/Rakefile +0 -6
  487. data/test/stub/rails4.1/app/assets/images/.keep +0 -0
  488. data/test/stub/rails4.1/app/assets/javascripts/application.js +0 -16
  489. data/test/stub/rails4.1/app/assets/stylesheets/application.css +0 -13
  490. data/test/stub/rails4.1/app/controllers/application_controller.rb +0 -5
  491. data/test/stub/rails4.1/app/controllers/concerns/.keep +0 -0
  492. data/test/stub/rails4.1/app/helpers/application_helper.rb +0 -2
  493. data/test/stub/rails4.1/app/mailers/.keep +0 -0
  494. data/test/stub/rails4.1/app/models/.keep +0 -0
  495. data/test/stub/rails4.1/app/models/concerns/.keep +0 -0
  496. data/test/stub/rails4.1/app/views/layouts/application.html.erb +0 -14
  497. data/test/stub/rails4.1/bin/bundle +0 -3
  498. data/test/stub/rails4.1/bin/rails +0 -4
  499. data/test/stub/rails4.1/bin/rake +0 -4
  500. data/test/stub/rails4.1/config.ru +0 -4
  501. data/test/stub/rails4.1/config/application.rb +0 -23
  502. data/test/stub/rails4.1/config/boot.rb +0 -4
  503. data/test/stub/rails4.1/config/database.yml +0 -25
  504. data/test/stub/rails4.1/config/environment.rb +0 -5
  505. data/test/stub/rails4.1/config/environments/development.rb +0 -29
  506. data/test/stub/rails4.1/config/environments/production.rb +0 -80
  507. data/test/stub/rails4.1/config/environments/test.rb +0 -36
  508. data/test/stub/rails4.1/config/initializers/backtrace_silencers.rb +0 -7
  509. data/test/stub/rails4.1/config/initializers/filter_parameter_logging.rb +0 -4
  510. data/test/stub/rails4.1/config/initializers/inflections.rb +0 -16
  511. data/test/stub/rails4.1/config/initializers/mime_types.rb +0 -5
  512. data/test/stub/rails4.1/config/initializers/passenger.rb +0 -5
  513. data/test/stub/rails4.1/config/initializers/secret_token.rb +0 -12
  514. data/test/stub/rails4.1/config/initializers/session_store.rb +0 -3
  515. data/test/stub/rails4.1/config/initializers/wrap_parameters.rb +0 -14
  516. data/test/stub/rails4.1/config/locales/en.yml +0 -23
  517. data/test/stub/rails4.1/config/routes.rb +0 -57
  518. data/test/stub/rails4.1/db/seeds.rb +0 -7
  519. data/test/stub/rails4.1/lib/assets/.keep +0 -0
  520. data/test/stub/rails4.1/lib/tasks/.keep +0 -0
  521. data/test/stub/rails4.1/log/.keep +0 -0
  522. data/test/stub/rails4.1/public/404.html +0 -58
  523. data/test/stub/rails4.1/public/422.html +0 -58
  524. data/test/stub/rails4.1/public/500.html +0 -57
  525. data/test/stub/rails4.1/public/favicon.ico +0 -0
  526. data/test/stub/rails4.1/public/robots.txt +0 -5
  527. data/test/stub/rails4.1/test/controllers/.keep +0 -0
  528. data/test/stub/rails4.1/test/fixtures/.keep +0 -0
  529. data/test/stub/rails4.1/test/helpers/.keep +0 -0
  530. data/test/stub/rails4.1/test/integration/.keep +0 -0
  531. data/test/stub/rails4.1/test/mailers/.keep +0 -0
  532. data/test/stub/rails4.1/test/models/.keep +0 -0
  533. data/test/stub/rails4.1/test/test_helper.rb +0 -15
  534. data/test/stub/rails4.1/vendor/assets/javascripts/.keep +0 -0
  535. data/test/stub/rails4.1/vendor/assets/stylesheets/.keep +0 -0
  536. data/test/stub/start_error.pl +0 -24
  537. data/test/stub/upload_data.txt +0 -494
  538. data/test/stub/wsgi/passenger_wsgi.py +0 -212
  539. data/test/stub/wsgi/public/.gitignore +0 -0
  540. data/test/stub/wsgi/tmp/.gitignore +0 -0
  541. data/test/support/allocate_memory.c +0 -14
  542. data/test/support/apache2_controller.rb +0 -258
  543. data/test/support/multipart.rb +0 -62
  544. data/test/support/nginx_controller.rb +0 -97
  545. data/test/support/placebo-preloader.rb +0 -88
  546. data/test/support/test_helper.rb +0 -455
  547. data/test/support/valgrind.h +0 -2539
  548. data/test/tut/tut.h +0 -1310
  549. data/test/tut/tut_reporter.h +0 -256
  550. data/test/valgrind-osx.supp +0 -7
@@ -1,758 +0,0 @@
1
- #include <TestSupport.h>
2
- #include <BackgroundEventLoop.h>
3
- #include <EventedBufferedInput.h>
4
- #include <Constants.h>
5
- #include <Utils.h>
6
- #include <Utils/IOUtils.h>
7
- #include <Utils/StrIntUtils.h>
8
-
9
- using namespace Passenger;
10
- using namespace std;
11
-
12
- namespace tut {
13
- class MyEventedBufferedInput: public EventedBufferedInput<> {
14
- public:
15
- boost::mutex syncher;
16
- int readError;
17
- boost::function<void ()> onAfterProcessingBuffer;
18
-
19
- MyEventedBufferedInput(SafeLibev *libev, const FileDescriptor &fd)
20
- : EventedBufferedInput<>(libev, fd)
21
- {
22
- readError = 0;
23
- }
24
-
25
- virtual ssize_t readSocket(void *buf, size_t n) {
26
- int readError;
27
- {
28
- boost::lock_guard<boost::mutex> l(syncher);
29
- readError = this->readError;
30
- }
31
- if (readError == 0) {
32
- return EventedBufferedInput<>::readSocket(buf, n);
33
- } else {
34
- errno = readError;
35
- return -1;
36
- }
37
- }
38
-
39
- void setReadError(int code) {
40
- boost::lock_guard<boost::mutex> l(syncher);
41
- readError = code;
42
- }
43
-
44
- virtual void afterProcessingBuffer() {
45
- boost::function<void ()> onAfterProcessingBuffer;
46
- {
47
- boost::lock_guard<boost::mutex> l(syncher);
48
- onAfterProcessingBuffer = this->onAfterProcessingBuffer;
49
- }
50
- if (onAfterProcessingBuffer) {
51
- onAfterProcessingBuffer();
52
- }
53
- }
54
- };
55
-
56
- struct EventedBufferedInputTest {
57
- BackgroundEventLoop bg;
58
- Pipe p;
59
- boost::shared_ptr<MyEventedBufferedInput> ebi;
60
- boost::mutex syncher;
61
- string log;
62
- ssize_t toConsume;
63
- unsigned int counter;
64
-
65
- EventedBufferedInputTest() {
66
- p = createPipe();
67
- ebi = boost::make_shared<MyEventedBufferedInput>(bg.safe.get(), p.first);
68
- ebi->onData = onData;
69
- ebi->onError = onError;
70
- ebi->userData = this;
71
- toConsume = -1;
72
- counter = 0;
73
- bg.start();
74
- }
75
-
76
- ~EventedBufferedInputTest() {
77
- bg.stop();
78
- setLogLevel(DEFAULT_LOG_LEVEL);
79
- }
80
-
81
- static size_t onData(const EventedBufferedInputPtr &input, const StaticString &data) {
82
- EventedBufferedInputTest *self = (EventedBufferedInputTest *) input->userData;
83
- boost::lock_guard<boost::mutex> l(self->syncher);
84
- self->counter++;
85
- if (data.empty()) {
86
- self->log.append("EOF\n");
87
- } else {
88
- self->log.append("Data: " + cEscapeString(data) + "\n");
89
- }
90
- if (self->toConsume == -1) {
91
- return data.size();
92
- } else {
93
- return self->toConsume;
94
- }
95
- }
96
-
97
- static void onError(const EventedBufferedInputPtr &input, const char *message, int code) {
98
- EventedBufferedInputTest *self = (EventedBufferedInputTest *) input->userData;
99
- boost::lock_guard<boost::mutex> l(self->syncher);
100
- self->log.append("Error: " + toString(code) + "\n");
101
- }
102
-
103
- unsigned int getCounter() {
104
- boost::lock_guard<boost::mutex> l(syncher);
105
- return counter;
106
- }
107
-
108
- void startEbi() {
109
- bg.safe->run(boost::bind(&EventedBufferedInputTest::realStartEbi, this));
110
- }
111
-
112
- void realStartEbi() {
113
- ebi->start();
114
- }
115
-
116
- bool ebiIsStarted() {
117
- bool result;
118
- bg.safe->run(boost::bind(&EventedBufferedInputTest::realEbiIsStarted, this, &result));
119
- return result;
120
- }
121
-
122
- void realEbiIsStarted(bool *result) {
123
- *result = ebi->isStarted();
124
- }
125
-
126
- void logEbiIsStarted() {
127
- boost::lock_guard<boost::mutex> l(syncher);
128
- log.append("isStarted: " + toString(ebi->isStarted()) + "\n");
129
- log.append("isSocketStarted: " + toString(ebi->isSocketStarted()) + "\n");
130
- }
131
- };
132
-
133
- #define LOCK() boost::lock_guard<boost::mutex> l(syncher)
134
-
135
- #define DEFINE_ON_DATA_METHOD(name, code) \
136
- static size_t name(const EventedBufferedInputPtr &input, const StaticString &data) { \
137
- EventedBufferedInputTest *self = (EventedBufferedInputTest *) input->userData; \
138
- boost::mutex &syncher = self->syncher; \
139
- string &log = self->log; \
140
- boost::shared_ptr<MyEventedBufferedInput> &ebi = self->ebi; \
141
- /* Shut up compiler warning */ \
142
- (void) syncher; \
143
- (void) log; \
144
- (void) ebi; \
145
- code \
146
- }
147
-
148
- #define DEFINE_FINISH_METHOD(name, code) \
149
- static void name(EventedBufferedInputTest *self) { \
150
- boost::mutex &syncher = self->syncher; \
151
- string &log = self->log; \
152
- boost::shared_ptr<MyEventedBufferedInput> &ebi = self->ebi; \
153
- /* Shut up compiler warning */ \
154
- (void) syncher; \
155
- (void) log; \
156
- (void) ebi; \
157
- code \
158
- }
159
-
160
- DEFINE_TEST_GROUP(EventedBufferedInputTest);
161
-
162
- TEST_METHOD(1) {
163
- set_test_name("It emits socket data events upon receiving data");
164
- startEbi();
165
- writeExact(p.second, "aaabbb");
166
- EVENTUALLY(5,
167
- LOCK();
168
- result = !log.empty();
169
- );
170
- LOCK();
171
- ensure_equals(log, "Data: aaabbb\n");
172
- }
173
-
174
- TEST_METHOD(2) {
175
- set_test_name("It emits socket end events upon receiving EOF");
176
- startEbi();
177
- p.second.close();
178
- EVENTUALLY(5,
179
- LOCK();
180
- result = !log.empty();
181
- );
182
- LOCK();
183
- ensure_equals(log, "EOF\n");
184
- }
185
-
186
- TEST_METHOD(3) {
187
- set_test_name("It emits socket end events after all data has been consumed");
188
- startEbi();
189
-
190
- writeExact(p.second, "aaabbb");
191
- EVENTUALLY(5,
192
- LOCK();
193
- result = !log.empty();
194
- );
195
- {
196
- LOCK();
197
- ensure_equals(log, "Data: aaabbb\n");
198
- }
199
-
200
- p.second.close();
201
- EVENTUALLY(5,
202
- LOCK();
203
- result = log.find("EOF") != string::npos;
204
- );
205
- {
206
- LOCK();
207
- ensure_equals(log,
208
- "Data: aaabbb\n"
209
- "EOF\n");
210
- }
211
- }
212
-
213
- TEST_METHOD(4) {
214
- set_test_name("Considers ended sockets to be paused");
215
- startEbi();
216
- p.second.close();
217
- EVENTUALLY(5,
218
- LOCK();
219
- result = !log.empty();
220
- );
221
- ensure(!ebiIsStarted());
222
- }
223
-
224
- TEST_METHOD(5) {
225
- set_test_name("It emits error events upon encountering a socket error");
226
- startEbi();
227
- ebi->setReadError(EIO);
228
- writeExact(p.second, "aaabbb");
229
- EVENTUALLY(5,
230
- LOCK();
231
- result = !log.empty();
232
- );
233
- LOCK();
234
- ensure_equals(log, "Error: " + toString(EIO) + "\n");
235
- }
236
-
237
- TEST_METHOD(6) {
238
- set_test_name("It emits error events after all data has been consumed");
239
- startEbi();
240
-
241
- writeExact(p.second, "aaabbb");
242
- EVENTUALLY(5,
243
- LOCK();
244
- result = !log.empty();
245
- );
246
-
247
- ebi->setReadError(EIO);
248
- writeExact(p.second, "x");
249
- EVENTUALLY(5,
250
- LOCK();
251
- result = log.find("Error") != string::npos;
252
- );
253
-
254
- LOCK();
255
- ensure_equals(log,
256
- "Data: aaabbb\n"
257
- "Error: " + toString(EIO) + "\n");
258
- }
259
-
260
- TEST_METHOD(7) {
261
- set_test_name("Considers error'ed sockets to be paused");
262
- startEbi();
263
- ebi->setReadError(EIO);
264
- writeExact(p.second, "x");
265
- EVENTUALLY(5,
266
- LOCK();
267
- result = !log.empty();
268
- );
269
- LOCK();
270
- ensure(!ebiIsStarted());
271
- }
272
-
273
- DEFINE_ON_DATA_METHOD(on_data_8,
274
- input->stop();
275
- self->bg.safe->runLater(boost::bind(&EventedBufferedInputTest::logEbiIsStarted, self));
276
- return 3;
277
- )
278
-
279
- TEST_METHOD(8) {
280
- set_test_name("If the onData callback consumes everything and pauses the "
281
- "EventedBufferedInput, then the EventedBufferedInput leaves the socket "
282
- "in the paused state");
283
-
284
- ebi->onData = on_data_8;
285
- startEbi();
286
- writeExact(p.second, "abc");
287
- EVENTUALLY(5,
288
- LOCK();
289
- result = !log.empty();
290
- );
291
- LOCK();
292
- ensure_equals(log,
293
- "isStarted: 0\n"
294
- "isSocketStarted: 0\n");
295
- }
296
-
297
- DEFINE_ON_DATA_METHOD(on_data_9,
298
- input->start();
299
- self->bg.safe->runLater(boost::bind(&EventedBufferedInputTest::logEbiIsStarted, self));
300
- return 3;
301
- )
302
-
303
- TEST_METHOD(9) {
304
- set_test_name("if the onData callback consumes everything and resumes the "
305
- "EventedBufferedInput, then the EventedBufferedInput leaves the socket "
306
- "in the resumed state");
307
-
308
- ebi->onData = on_data_9;
309
- startEbi();
310
- writeExact(p.second, "abc");
311
- EVENTUALLY(5,
312
- LOCK();
313
- result = !log.empty();
314
- );
315
- LOCK();
316
- ensure_equals(log,
317
- "isStarted: 1\n"
318
- "isSocketStarted: 1\n");
319
- }
320
-
321
- DEFINE_ON_DATA_METHOD(on_data_10,
322
- input->stop();
323
- self->bg.safe->runLater(boost::bind(&EventedBufferedInputTest::logEbiIsStarted, self));
324
- return 1;
325
- )
326
-
327
- TEST_METHOD(10) {
328
- set_test_name("If the onData callback consumes partially and pauses the "
329
- "EventedBufferedInput, then the EventedBufferedInput leaves the socket "
330
- "at the paused state");
331
-
332
- ebi->onData = on_data_10;
333
- startEbi();
334
- writeExact(p.second, "abc");
335
- EVENTUALLY(5,
336
- LOCK();
337
- result = !log.empty();
338
- );
339
- LOCK();
340
- ensure_equals(log,
341
- "isStarted: 0\n"
342
- "isSocketStarted: 0\n");
343
- }
344
-
345
- DEFINE_ON_DATA_METHOD(on_data_11,
346
- input->start();
347
- self->bg.safe->runLater(boost::bind(&EventedBufferedInputTest::logEbiIsStarted, self));
348
- return 1;
349
- )
350
-
351
- TEST_METHOD(11) {
352
- set_test_name("If the onData callback consumes partially and resumes the "
353
- "EventedBufferedInput, then the EventedBufferedInput leaves the socket "
354
- "at the resumed state");
355
-
356
- ebi->onData = on_data_11;
357
- startEbi();
358
- writeExact(p.second, "ab");
359
- EVENTUALLY(5,
360
- LOCK();
361
- result = log ==
362
- "isStarted: 1\n"
363
- "isSocketStarted: 0\n"
364
- "isStarted: 1\n"
365
- "isSocketStarted: 1\n";
366
- );
367
- }
368
-
369
- DEFINE_ON_DATA_METHOD(on_data_12,
370
- LOCK();
371
- self->counter++;
372
- if (self->counter == 2) {
373
- input->stop();
374
- self->bg.safe->runLater(boost::bind(&EventedBufferedInputTest::logEbiIsStarted, self));
375
- }
376
- return 2;
377
- )
378
-
379
- TEST_METHOD(12) {
380
- set_test_name("If the onData callback first consumes partially, then "
381
- "consumes everything and pauses the EventedBufferedInput, then the "
382
- "EventedBufferedInput leaves the socket in the paused state");
383
-
384
- ebi->onData = on_data_12;
385
- startEbi();
386
- writeExact(p.second, "aabb");
387
- EVENTUALLY(5,
388
- LOCK();
389
- result = !log.empty();
390
- );
391
- LOCK();
392
- ensure_equals(log,
393
- "isStarted: 0\n"
394
- "isSocketStarted: 0\n");
395
- }
396
-
397
- DEFINE_ON_DATA_METHOD(on_data_13,
398
- LOCK();
399
- self->counter++;
400
- if (self->counter == 2) {
401
- input->start();
402
- self->bg.safe->runLater(boost::bind(&EventedBufferedInputTest::logEbiIsStarted, self));
403
- }
404
- return 2;
405
- )
406
-
407
- TEST_METHOD(13) {
408
- set_test_name("If the onData callback first consumes partially, then "
409
- "consumes everything and resumes the EventedBufferedInput, then the "
410
- "EventedBufferedInput leaves the socket in the resumed state");
411
-
412
- ebi->onData = on_data_13;
413
- startEbi();
414
- writeExact(p.second, "aabb");
415
- EVENTUALLY(5,
416
- LOCK();
417
- result = !log.empty();
418
- );
419
- LOCK();
420
- ensure_equals(log,
421
- "isStarted: 1\n"
422
- "isSocketStarted: 1\n");
423
- }
424
-
425
-
426
- /*** If the onData callback didn't consume everything... ***/
427
-
428
- DEFINE_ON_DATA_METHOD(on_data_20,
429
- LOCK();
430
- self->counter++;
431
- self->log.append("onData called; isSocketStarted: " +
432
- toString(self->ebi->isSocketStarted()) + "\n");
433
- self->log.append("Data: " + cEscapeString(data) + "\n");
434
- if (self->counter == 1) {
435
- return 3;
436
- } else {
437
- return 1;
438
- }
439
- )
440
-
441
- static void on_after_processing_buffer_20(EventedBufferedInputTest *self) {
442
- boost::lock_guard<boost::mutex> l(self->syncher);
443
- if (self->counter == 1) {
444
- self->log.append("Finished first onData; isSocketStarted: " +
445
- toString(self->ebi->isSocketStarted()) + "\n");
446
- }
447
- }
448
-
449
- DEFINE_FINISH_METHOD(finish_20,
450
- LOCK();
451
- log.append("Finished; isSocketStarted: " +
452
- toString(ebi->isSocketStarted()) + "\n");
453
- );
454
-
455
- TEST_METHOD(20) {
456
- set_test_name("It pauses the socket, re-emits the remaining data in the next tick, "
457
- "then resumes the socket when everything is consumed");
458
-
459
- ebi->onData = on_data_20;
460
- ebi->onAfterProcessingBuffer = boost::bind(on_after_processing_buffer_20, this);
461
- startEbi();
462
- writeExact(p.second, "aaabbb");
463
- bg.safe->runAfterTS(10, boost::bind(finish_20, this));
464
-
465
- EVENTUALLY(5,
466
- LOCK();
467
- result = log.find("Finished;") != string::npos;
468
- );
469
- LOCK();
470
- ensure_equals(log,
471
- "onData called; isSocketStarted: 1\n"
472
- "Data: aaabbb\n"
473
- "Finished first onData; isSocketStarted: 0\n"
474
- "onData called; isSocketStarted: 0\n"
475
- "Data: bbb\n"
476
- "onData called; isSocketStarted: 0\n"
477
- "Data: bb\n"
478
- "onData called; isSocketStarted: 0\n"
479
- "Data: b\n"
480
- "Finished; isSocketStarted: 1\n");
481
- }
482
-
483
- /*** If pause() is called after the data handler... ***/
484
-
485
- static void on_after_processing_buffer_21(EventedBufferedInputTest *self) {
486
- if (self->getCounter() == 1) {
487
- self->ebi->stop();
488
- boost::lock_guard<boost::mutex> l(self->syncher);
489
- self->log.append("isSocketStarted: " +
490
- toString(self->ebi->isSocketStarted()) + "\n");
491
- }
492
- }
493
-
494
- TEST_METHOD(21) {
495
- set_test_name("It pauses the socket and doesn't re-emit remaining data events");
496
- toConsume = 1;
497
- ebi->onAfterProcessingBuffer = boost::bind(on_after_processing_buffer_21, this);
498
- startEbi();
499
- writeExact(p.second, "aaabbb");
500
- EVENTUALLY(5,
501
- LOCK();
502
- result = log.find("isSocketStarted") != string::npos;
503
- );
504
- LOCK();
505
- ensure_equals(log,
506
- "Data: aaabbb\n"
507
- "isSocketStarted: 0\n");
508
- }
509
-
510
- static void on_after_processing_buffer_22(EventedBufferedInputTest *self) {
511
- if (self->getCounter() == 1) {
512
- self->ebi->stop();
513
- {
514
- boost::lock_guard<boost::mutex> l(self->syncher);
515
- self->log.append("Paused; isSocketStarted: " +
516
- toString(self->ebi->isSocketStarted()) + "\n");
517
- }
518
- self->ebi->start();
519
- {
520
- boost::lock_guard<boost::mutex> l(self->syncher);
521
- self->log.append("Resumed; isSocketStarted: " +
522
- toString(self->ebi->isSocketStarted()) + "\n");
523
- }
524
- }
525
- }
526
-
527
- DEFINE_FINISH_METHOD(finish_22,
528
- LOCK();
529
- log.append("Done; isSocketStarted: " +
530
- toString(ebi->isStarted()) + "\n");
531
- );
532
-
533
- TEST_METHOD(22) {
534
- set_test_name("It resumes the socket and re-emits remaining "
535
- "data one tick after start() is called");
536
- toConsume = 3;
537
- ebi->onAfterProcessingBuffer = boost::bind(on_after_processing_buffer_22, this);
538
- startEbi();
539
- writeExact(p.second, "aaabbb");
540
- bg.safe->runAfterTS(10, boost::bind(finish_22, this));
541
- EVENTUALLY(5,
542
- LOCK();
543
- result = log.find("Done") != string::npos;
544
- );
545
- {
546
- LOCK();
547
- ensure_equals(log,
548
- "Data: aaabbb\n"
549
- "Paused; isSocketStarted: 0\n"
550
- "Resumed; isSocketStarted: 0\n"
551
- "Data: bbb\n"
552
- "Done; isSocketStarted: 1\n");
553
- }
554
-
555
- bg.safe->runAfterTS(10, boost::bind(finish_22, this));
556
- startEbi();
557
- EVENTUALLY(5,
558
- LOCK();
559
- result = log.find("Done") != string::npos;
560
- );
561
- }
562
-
563
- static void on_after_processing_buffer_23(EventedBufferedInputTest *self) {
564
- if (self->getCounter() == 1) {
565
- self->ebi->stop();
566
- {
567
- boost::lock_guard<boost::mutex> l(self->syncher);
568
- self->log.append("Paused; isSocketStarted: " +
569
- toString(self->ebi->isSocketStarted()) + "\n");
570
- }
571
- self->ebi->start();
572
- {
573
- boost::lock_guard<boost::mutex> l(self->syncher);
574
- self->log.append("Resumed; isSocketStarted: " +
575
- toString(self->ebi->isSocketStarted()) + "\n");
576
- }
577
- self->ebi->stop();
578
- {
579
- boost::lock_guard<boost::mutex> l(self->syncher);
580
- self->log.append("Paused again; isSocketStarted: " +
581
- toString(self->ebi->isSocketStarted()) + "\n");
582
- }
583
- }
584
- }
585
-
586
- DEFINE_FINISH_METHOD(finish_23,
587
- LOCK();
588
- log.append("Timeout; isSocketStarted: " +
589
- toString(ebi->isStarted()) + "\n");
590
- );
591
-
592
- TEST_METHOD(23) {
593
- set_test_name("It doesn't re-emit remaining data if start() "
594
- "is called, then stop() again");
595
- toConsume = 3;
596
- ebi->onAfterProcessingBuffer = boost::bind(on_after_processing_buffer_23, this);
597
- startEbi();
598
- writeExact(p.second, "aaabbb");
599
- bg.safe->runAfterTS(10, boost::bind(finish_23, this));
600
- EVENTUALLY(5,
601
- LOCK();
602
- result = log.find("Timeout") != string::npos;
603
- );
604
- LOCK();
605
- ensure_equals(log,
606
- "Data: aaabbb\n"
607
- "Paused; isSocketStarted: 0\n"
608
- "Resumed; isSocketStarted: 0\n"
609
- "Paused again; isSocketStarted: 0\n"
610
- "Timeout; isSocketStarted: 0\n");
611
- }
612
-
613
- /*** If pause() is called during the handler ***/
614
-
615
- DEFINE_ON_DATA_METHOD(on_data_24,
616
- {
617
- LOCK();
618
- self->counter++;
619
- self->log.append("Data: " + cEscapeString(data) + "\n");
620
- }
621
- if (self->getCounter() == 1) {
622
- input->stop();
623
- }
624
- return 1;
625
- )
626
-
627
- DEFINE_FINISH_METHOD(finish_24,
628
- LOCK();
629
- log.append("Timeout; isSocketStarted: " +
630
- toString(ebi->isSocketStarted()) + "\n");
631
- );
632
-
633
- TEST_METHOD(24) {
634
- set_test_name("It pauses the socket and doesn't re-emit remaining data");
635
- ebi->onData = on_data_24;
636
- startEbi();
637
- writeExact(p.second, "aaabbb");
638
- bg.safe->runAfterTS(10, boost::bind(finish_24, this));
639
- EVENTUALLY(5,
640
- LOCK();
641
- result = log.find("Timeout") != string::npos;
642
- );
643
- LOCK();
644
- ensure_equals(log,
645
- "Data: aaabbb\n"
646
- "Timeout; isSocketStarted: 0\n");
647
- }
648
-
649
- DEFINE_ON_DATA_METHOD(on_data_25,
650
- {
651
- LOCK();
652
- self->counter++;
653
- self->log.append("Data: " + cEscapeString(data) + "\n");
654
- }
655
- if (self->getCounter() == 1) {
656
- input->stop();
657
- input->start();
658
- }
659
- return 3;
660
- )
661
-
662
- static void on_after_processing_buffer_25(EventedBufferedInputTest *self) {
663
- boost::lock_guard<boost::mutex> l(self->syncher);
664
- if (self->counter == 1) {
665
- self->log.append("Handler done; isSocketStarted: " +
666
- toString(self->ebi->isSocketStarted()) + "\n");
667
- }
668
- }
669
-
670
- DEFINE_FINISH_METHOD(finish_25,
671
- LOCK();
672
- log.append("Timeout; isSocketStarted: " +
673
- toString(ebi->isStarted()) + "\n");
674
- );
675
-
676
- TEST_METHOD(25) {
677
- set_test_name("It re-emits remaining data one tick after start() is called");
678
- ebi->onData = on_data_25;
679
- ebi->onAfterProcessingBuffer = boost::bind(on_after_processing_buffer_25, this);
680
- startEbi();
681
- writeExact(p.second, "aaabbb");
682
- bg.safe->runAfterTS(10, boost::bind(finish_25, this));
683
- EVENTUALLY(5,
684
- LOCK();
685
- result = log.find("Timeout") != string::npos;
686
- );
687
- LOCK();
688
- ensure_equals(log,
689
- "Data: aaabbb\n"
690
- "Handler done; isSocketStarted: 0\n"
691
- "Data: bbb\n"
692
- "Timeout; isSocketStarted: 1\n");
693
- }
694
-
695
- DEFINE_ON_DATA_METHOD(on_data_26,
696
- {
697
- LOCK();
698
- self->counter++;
699
- self->log.append("Data: " + cEscapeString(data) + "\n");
700
- }
701
- if (self->getCounter() == 1) {
702
- input->stop();
703
- input->start();
704
- input->stop();
705
- }
706
- return 3;
707
- )
708
-
709
- static void on_after_processing_buffer_26(EventedBufferedInputTest *self) {
710
- boost::lock_guard<boost::mutex> l(self->syncher);
711
- if (self->counter == 1) {
712
- self->log.append("Handler done; isSocketStarted: " +
713
- toString(self->ebi->isSocketStarted()) + "\n");
714
- }
715
- }
716
-
717
- DEFINE_FINISH_METHOD(finish_26,
718
- LOCK();
719
- log.append("Timeout; isSocketStarted: " +
720
- toString(ebi->isSocketStarted()) + "\n");
721
- );
722
-
723
- TEST_METHOD(26) {
724
- set_test_name("It doesn't re-emit remaining data if start() is called, then stop() again");
725
- ebi->onData = on_data_26;
726
- ebi->onAfterProcessingBuffer = boost::bind(on_after_processing_buffer_26, this);
727
- startEbi();
728
- writeExact(p.second, "aaabbb");
729
- bg.safe->runAfterTS(10, boost::bind(finish_26, this));
730
- EVENTUALLY(5,
731
- LOCK();
732
- result = log.find("Timeout") != string::npos;
733
- );
734
- LOCK();
735
- ensure_equals(log,
736
- "Data: aaabbb\n"
737
- "Handler done; isSocketStarted: 0\n"
738
- "Timeout; isSocketStarted: 0\n");
739
- }
740
-
741
- /*** If the socket was disconnected ***/
742
-
743
- TEST_METHOD(27) {
744
- set_test_name("It doesn't re-emit the remaining data");
745
- // TODO
746
- }
747
-
748
- TEST_METHOD(30) {
749
- set_test_name("It pauses the underlying socket");
750
- // TODO
751
- }
752
-
753
- TEST_METHOD(31) {
754
- set_test_name("It doesn't emit data events if it's paused, but re-emits "
755
- "previously unemitted data events after resume");
756
- // TODO
757
- }
758
- }