passenger 5.0.0.beta3 → 5.0.0.rc1

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 (218) hide show
  1. checksums.yaml +8 -8
  2. checksums.yaml.gz.asc +7 -7
  3. data.tar.gz.asc +7 -7
  4. data/.editorconfig +11 -5
  5. data/CHANGELOG +38 -0
  6. data/CONTRIBUTING.md +1 -4
  7. data/Gemfile +0 -1
  8. data/Gemfile.lock +0 -2
  9. data/Rakefile +33 -33
  10. data/bin/passenger +1 -1
  11. data/bin/passenger-config +1 -1
  12. data/bin/passenger-install-apache2-module +800 -800
  13. data/bin/passenger-install-nginx-module +592 -592
  14. data/bin/passenger-memory-stats +127 -127
  15. data/bin/passenger-status +216 -216
  16. data/build/agents.rb +127 -127
  17. data/build/apache2.rb +87 -87
  18. data/build/basics.rb +60 -60
  19. data/build/common_library.rb +165 -165
  20. data/build/cplusplus_support.rb +51 -51
  21. data/build/cxx_tests.rb +268 -268
  22. data/build/debian.rb +143 -143
  23. data/build/documentation.rb +58 -58
  24. data/build/integration_tests.rb +81 -81
  25. data/build/misc.rb +132 -132
  26. data/build/nginx.rb +20 -20
  27. data/build/node_tests.rb +7 -7
  28. data/build/oxt_tests.rb +14 -14
  29. data/build/packaging.rb +570 -570
  30. data/build/preprocessor.rb +260 -260
  31. data/build/rake_extensions.rb +71 -71
  32. data/build/ruby_extension.rb +29 -29
  33. data/build/ruby_tests.rb +6 -6
  34. data/build/test_basics.rb +37 -37
  35. data/debian.template/control.template +3 -5
  36. data/dev/copy_boost_headers +134 -134
  37. data/dev/install_scripts_bootstrap_code.rb +25 -25
  38. data/dev/list_tests +20 -20
  39. data/dev/ruby_server.rb +223 -223
  40. data/dev/runner +18 -18
  41. data/doc/ServerOptimizationGuide.txt.md +55 -2
  42. data/doc/Users guide Nginx.txt +0 -26
  43. data/doc/Users guide Standalone.txt +5 -1
  44. data/doc/users_guide_snippets/tips.txt +9 -0
  45. data/ext/common/ApplicationPool2/Group.h +23 -11
  46. data/ext/common/ApplicationPool2/Implementation.cpp +32 -7
  47. data/ext/common/ApplicationPool2/Pool.h +22 -17
  48. data/ext/common/ApplicationPool2/SmartSpawner.h +4 -1
  49. data/ext/common/ApplicationPool2/Spawner.h +1 -1
  50. data/ext/common/Constants.h +1 -1
  51. data/ext/common/agents/Base.cpp +35 -20
  52. data/ext/common/agents/HelperAgent/Main.cpp +8 -1
  53. data/ext/common/agents/HelperAgent/OptionParser.h +18 -4
  54. data/ext/common/agents/HelperAgent/RequestHandler.h +2 -83
  55. data/ext/common/agents/HelperAgent/RequestHandler/ForwardResponse.cpp +54 -1
  56. data/ext/common/agents/HelperAgent/RequestHandler/InitRequest.cpp +7 -4
  57. data/ext/common/agents/Main.cpp +1 -1
  58. data/ext/common/agents/Watchdog/Main.cpp +54 -19
  59. data/ext/nginx/Configuration.c +7 -0
  60. data/ext/nginx/ContentHandler.c +9 -1
  61. data/helper-scripts/backtrace-sanitizer.rb +106 -87
  62. data/helper-scripts/crash-watch.rb +32 -0
  63. data/helper-scripts/download_binaries/extconf.rb +38 -38
  64. data/helper-scripts/meteor-loader.rb +107 -107
  65. data/helper-scripts/prespawn +101 -101
  66. data/helper-scripts/rack-loader.rb +96 -96
  67. data/helper-scripts/rack-preloader.rb +137 -137
  68. data/lib/phusion_passenger.rb +292 -292
  69. data/lib/phusion_passenger/abstract_installer.rb +438 -438
  70. data/lib/phusion_passenger/active_support3_extensions/init.rb +168 -170
  71. data/lib/phusion_passenger/admin_tools.rb +20 -20
  72. data/lib/phusion_passenger/admin_tools/instance.rb +178 -178
  73. data/lib/phusion_passenger/admin_tools/instance_registry.rb +61 -61
  74. data/lib/phusion_passenger/admin_tools/memory_stats.rb +267 -267
  75. data/lib/phusion_passenger/apache2/config_options.rb +182 -182
  76. data/lib/phusion_passenger/common_library.rb +479 -485
  77. data/lib/phusion_passenger/config/about_command.rb +161 -161
  78. data/lib/phusion_passenger/config/admin_command_command.rb +129 -129
  79. data/lib/phusion_passenger/config/agent_compiler.rb +121 -121
  80. data/lib/phusion_passenger/config/build_native_support_command.rb +43 -43
  81. data/lib/phusion_passenger/config/command.rb +25 -25
  82. data/lib/phusion_passenger/config/compile_agent_command.rb +62 -62
  83. data/lib/phusion_passenger/config/compile_nginx_engine_command.rb +88 -73
  84. data/lib/phusion_passenger/config/detach_process_command.rb +72 -72
  85. data/lib/phusion_passenger/config/download_agent_command.rb +246 -227
  86. data/lib/phusion_passenger/config/download_nginx_engine_command.rb +245 -224
  87. data/lib/phusion_passenger/config/install_agent_command.rb +144 -132
  88. data/lib/phusion_passenger/config/install_standalone_runtime_command.rb +205 -185
  89. data/lib/phusion_passenger/config/installation_utils.rb +204 -204
  90. data/lib/phusion_passenger/config/list_instances_command.rb +64 -64
  91. data/lib/phusion_passenger/config/main.rb +152 -152
  92. data/lib/phusion_passenger/config/nginx_engine_compiler.rb +319 -300
  93. data/lib/phusion_passenger/config/reopen_logs_command.rb +67 -67
  94. data/lib/phusion_passenger/config/restart_app_command.rb +155 -155
  95. data/lib/phusion_passenger/config/system_metrics_command.rb +13 -13
  96. data/lib/phusion_passenger/config/utils.rb +95 -95
  97. data/lib/phusion_passenger/config/validate_install_command.rb +198 -198
  98. data/lib/phusion_passenger/console_text_template.rb +25 -25
  99. data/lib/phusion_passenger/constants.rb +90 -90
  100. data/lib/phusion_passenger/debug_logging.rb +106 -106
  101. data/lib/phusion_passenger/loader_shared_helpers.rb +447 -432
  102. data/lib/phusion_passenger/message_channel.rb +312 -312
  103. data/lib/phusion_passenger/message_client.rb +176 -176
  104. data/lib/phusion_passenger/native_support.rb +369 -369
  105. data/lib/phusion_passenger/nginx/config_options.rb +297 -297
  106. data/lib/phusion_passenger/packaging.rb +131 -131
  107. data/lib/phusion_passenger/platform_info.rb +360 -360
  108. data/lib/phusion_passenger/platform_info/apache.rb +767 -767
  109. data/lib/phusion_passenger/platform_info/apache_detector.rb +199 -199
  110. data/lib/phusion_passenger/platform_info/binary_compatibility.rb +107 -107
  111. data/lib/phusion_passenger/platform_info/compiler.rb +570 -570
  112. data/lib/phusion_passenger/platform_info/curl.rb +32 -32
  113. data/lib/phusion_passenger/platform_info/cxx_portability.rb +188 -188
  114. data/lib/phusion_passenger/platform_info/depcheck.rb +372 -372
  115. data/lib/phusion_passenger/platform_info/depcheck_specs/apache2.rb +109 -109
  116. data/lib/phusion_passenger/platform_info/depcheck_specs/compiler_toolchain.rb +4 -4
  117. data/lib/phusion_passenger/platform_info/depcheck_specs/gems.rb +10 -34
  118. data/lib/phusion_passenger/platform_info/depcheck_specs/libs.rb +101 -101
  119. data/lib/phusion_passenger/platform_info/depcheck_specs/ruby.rb +5 -5
  120. data/lib/phusion_passenger/platform_info/depcheck_specs/utilities.rb +13 -13
  121. data/lib/phusion_passenger/platform_info/linux.rb +55 -55
  122. data/lib/phusion_passenger/platform_info/operating_system.rb +149 -149
  123. data/lib/phusion_passenger/platform_info/ruby.rb +468 -448
  124. data/lib/phusion_passenger/platform_info/zlib.rb +9 -9
  125. data/lib/phusion_passenger/plugin.rb +66 -66
  126. data/lib/phusion_passenger/preloader_shared_helpers.rb +126 -126
  127. data/lib/phusion_passenger/public_api.rb +191 -191
  128. data/lib/phusion_passenger/rack/out_of_band_gc.rb +93 -94
  129. data/lib/phusion_passenger/rack/thread_handler_extension.rb +231 -227
  130. data/lib/phusion_passenger/request_handler.rb +567 -577
  131. data/lib/phusion_passenger/request_handler/thread_handler.rb +379 -381
  132. data/lib/phusion_passenger/ruby_core_enhancements.rb +86 -86
  133. data/lib/phusion_passenger/ruby_core_io_enhancements.rb +74 -74
  134. data/lib/phusion_passenger/simple_benchmarking.rb +25 -25
  135. data/lib/phusion_passenger/standalone/app_finder.rb +153 -150
  136. data/lib/phusion_passenger/standalone/command.rb +44 -40
  137. data/lib/phusion_passenger/standalone/config_utils.rb +53 -53
  138. data/lib/phusion_passenger/standalone/control_utils.rb +38 -59
  139. data/lib/phusion_passenger/standalone/main.rb +73 -73
  140. data/lib/phusion_passenger/standalone/start_command.rb +697 -685
  141. data/lib/phusion_passenger/standalone/start_command/builtin_engine.rb +193 -155
  142. data/lib/phusion_passenger/standalone/start_command/nginx_engine.rb +162 -133
  143. data/lib/phusion_passenger/standalone/status_command.rb +64 -64
  144. data/lib/phusion_passenger/standalone/stop_command.rb +72 -72
  145. data/lib/phusion_passenger/standalone/version_command.rb +9 -9
  146. data/lib/phusion_passenger/union_station/connection.rb +32 -32
  147. data/lib/phusion_passenger/union_station/core.rb +251 -251
  148. data/lib/phusion_passenger/union_station/transaction.rb +126 -126
  149. data/lib/phusion_passenger/utils.rb +199 -167
  150. data/lib/phusion_passenger/utils/ansi_colors.rb +128 -128
  151. data/lib/phusion_passenger/utils/download.rb +196 -196
  152. data/lib/phusion_passenger/utils/file_system_watcher.rb +158 -158
  153. data/lib/phusion_passenger/utils/hosts_file_parser.rb +101 -101
  154. data/lib/phusion_passenger/utils/lock.rb +31 -31
  155. data/lib/phusion_passenger/utils/native_support_utils.rb +31 -31
  156. data/lib/phusion_passenger/utils/progress_bar.rb +26 -26
  157. data/lib/phusion_passenger/utils/shellwords.rb +20 -20
  158. data/lib/phusion_passenger/utils/terminal_choice_menu.rb +206 -206
  159. data/lib/phusion_passenger/utils/unseekable_socket.rb +272 -272
  160. data/lib/phusion_passenger/vendor/crash_watch/app.rb +129 -0
  161. data/lib/phusion_passenger/vendor/crash_watch/gdb_controller.rb +341 -0
  162. data/lib/phusion_passenger/vendor/crash_watch/version.rb +24 -0
  163. data/lib/phusion_passenger/vendor/daemon_controller.rb +877 -0
  164. data/lib/phusion_passenger/vendor/daemon_controller/lock_file.rb +127 -0
  165. data/lib/phusion_passenger/vendor/daemon_controller/spawn.rb +26 -0
  166. data/lib/phusion_passenger/vendor/daemon_controller/version.rb +29 -0
  167. data/packaging/rpm/passenger_spec/passenger.spec.template +0 -1
  168. data/passenger.gemspec +0 -1
  169. data/resources/templates/config/nginx_engine_compiler/possible_solutions_for_download_and_extraction_problems.txt.erb +27 -0
  170. data/resources/templates/standalone/config.erb +19 -15
  171. data/test/integration_tests/apache2_tests.rb +566 -566
  172. data/test/integration_tests/downloaded_binaries_tests.rb +126 -125
  173. data/test/integration_tests/native_packaging_spec.rb +296 -296
  174. data/test/integration_tests/nginx_tests.rb +393 -393
  175. data/test/integration_tests/shared/example_webapp_tests.rb +282 -280
  176. data/test/integration_tests/source_packaging_test.rb +138 -138
  177. data/test/integration_tests/spec_helper.rb +5 -5
  178. data/test/integration_tests/standalone_tests.rb +367 -367
  179. data/test/ruby/debug_logging_spec.rb +133 -133
  180. data/test/ruby/message_channel_spec.rb +186 -186
  181. data/test/ruby/rack/loader_spec.rb +28 -28
  182. data/test/ruby/rack/preloader_spec.rb +34 -34
  183. data/test/ruby/rails3.0/loader_spec.rb +12 -12
  184. data/test/ruby/rails3.0/preloader_spec.rb +18 -18
  185. data/test/ruby/rails3.1/loader_spec.rb +12 -12
  186. data/test/ruby/rails3.1/preloader_spec.rb +18 -18
  187. data/test/ruby/rails3.2/loader_spec.rb +12 -12
  188. data/test/ruby/rails3.2/preloader_spec.rb +18 -18
  189. data/test/ruby/rails4.0/loader_spec.rb +12 -12
  190. data/test/ruby/rails4.0/preloader_spec.rb +18 -18
  191. data/test/ruby/rails4.1/loader_spec.rb +12 -12
  192. data/test/ruby/rails4.1/preloader_spec.rb +18 -18
  193. data/test/ruby/request_handler_spec.rb +730 -730
  194. data/test/ruby/shared/loader_sharedspec.rb +224 -224
  195. data/test/ruby/shared/rails/union_station_extensions_sharedspec.rb +327 -327
  196. data/test/ruby/shared/ruby_loader_sharedspec.rb +47 -47
  197. data/test/ruby/spec_helper.rb +65 -65
  198. data/test/ruby/standalone/runtime_installer_spec.rb +384 -384
  199. data/test/ruby/union_station_spec.rb +276 -276
  200. data/test/ruby/utils/file_system_watcher_spec.rb +220 -220
  201. data/test/ruby/utils/hosts_file_parser.rb +248 -248
  202. data/test/ruby/utils/tee_input_spec.rb +215 -215
  203. data/test/ruby/utils/unseekable_socket_spec.rb +57 -57
  204. data/test/ruby/utils_spec.rb +21 -21
  205. data/test/stub/rack/config.ru +87 -87
  206. data/test/stub/rack/library.rb +8 -8
  207. data/test/stub/rack/start.rb +30 -30
  208. data/test/support/apache2_controller.rb +191 -191
  209. data/test/support/nginx_controller.rb +90 -99
  210. data/test/support/placebo-preloader.rb +57 -57
  211. data/test/support/test_helper.rb +435 -435
  212. metadata +11 -21
  213. metadata.gz.asc +7 -7
  214. data/lib/phusion_passenger/standalone/command2.rb +0 -292
  215. data/lib/phusion_passenger/standalone/start2_command.rb +0 -799
  216. data/resources/templates/standalone/download_tool_missing.txt.erb +0 -18
  217. data/resources/templates/standalone/possible_solutions_for_download_and_extraction_problems.txt.erb +0 -17
  218. data/resources/templates/standalone/run_installer_as_root.txt.erb +0 -8
@@ -1,55 +1,55 @@
1
1
  module PhusionPassenger
2
2
 
3
3
  shared_examples_for "a Ruby loader" do
4
- it "prints an error page if the startup file fails to load" do
5
- File.write(@stub.startup_file, %q{
6
- raise "oh no!"
7
- })
8
- result = start
9
- result[:status].should == "Error"
10
- result[:body].should include("oh no!")
11
- end
4
+ it "prints an error page if the startup file fails to load" do
5
+ File.write(@stub.startup_file, %q{
6
+ raise "oh no!"
7
+ })
8
+ result = start
9
+ result[:status].should == "Error"
10
+ result[:body].should include("oh no!")
11
+ end
12
12
 
13
- it "calls the starting_worker_process event after the startup file has been loaded" do
14
- File.prepend(@stub.startup_file, %q{
15
- history_file = "history.txt"
16
- PhusionPassenger.on_event(:starting_worker_process) do |forked|
17
- ::File.open(history_file, 'a') do |f|
18
- f.puts "worker_process_started\n"
19
- end
20
- end
21
- ::File.open(history_file, 'a') do |f|
22
- f.puts "end of startup file\n"
23
- end
24
- })
25
- result = start
26
- result[:status].should == "Ready"
27
- File.read("#{@stub.app_root}/history.txt").should ==
28
- "end of startup file\n" +
29
- "worker_process_started\n"
30
- end
13
+ it "calls the starting_worker_process event after the startup file has been loaded" do
14
+ File.prepend(@stub.startup_file, %q{
15
+ history_file = "history.txt"
16
+ PhusionPassenger.on_event(:starting_worker_process) do |forked|
17
+ ::File.open(history_file, 'a') do |f|
18
+ f.puts "worker_process_started\n"
19
+ end
20
+ end
21
+ ::File.open(history_file, 'a') do |f|
22
+ f.puts "end of startup file\n"
23
+ end
24
+ })
25
+ result = start
26
+ result[:status].should == "Ready"
27
+ File.read("#{@stub.app_root}/history.txt").should ==
28
+ "end of startup file\n" +
29
+ "worker_process_started\n"
30
+ end
31
31
 
32
- it "calls the stopping_worker_process event on exit" do
33
- File.prepend(@stub.startup_file, %q{
34
- history_file = "history.txt"
35
- PhusionPassenger.on_event(:stopping_worker_process) do
36
- ::File.open(history_file, 'a') do |f|
37
- f.puts "worker_process_stopped\n"
38
- end
39
- end
40
- ::File.open(history_file, 'a') do |f|
41
- f.puts "end of startup file\n"
42
- end
43
- })
44
- result = start
45
- result[:status].should == "Ready"
46
- @loader.input.close_write
47
- eventually(3) do
48
- File.read("#{@stub.app_root}/history.txt") ==
49
- "end of startup file\n" +
50
- "worker_process_stopped\n"
51
- end
52
- end
32
+ it "calls the stopping_worker_process event on exit" do
33
+ File.prepend(@stub.startup_file, %q{
34
+ history_file = "history.txt"
35
+ PhusionPassenger.on_event(:stopping_worker_process) do
36
+ ::File.open(history_file, 'a') do |f|
37
+ f.puts "worker_process_stopped\n"
38
+ end
39
+ end
40
+ ::File.open(history_file, 'a') do |f|
41
+ f.puts "end of startup file\n"
42
+ end
43
+ })
44
+ result = start
45
+ result[:status].should == "Ready"
46
+ @loader.input.close_write
47
+ eventually(3) do
48
+ File.read("#{@stub.app_root}/history.txt") ==
49
+ "end of startup file\n" +
50
+ "worker_process_stopped\n"
51
+ end
52
+ end
53
53
  end
54
54
 
55
55
  end # module PhusionPassenger
@@ -1,5 +1,5 @@
1
1
  if GC.respond_to?(:copy_on_write_friendly?) && !GC.copy_on_write_friendly?
2
- GC.copy_on_write_friendly = true
2
+ GC.copy_on_write_friendly = true
3
3
  end
4
4
 
5
5
  RUBY_VERSION_INT = RUBY_VERSION.split('.')[0..2].join.to_i
@@ -10,21 +10,21 @@ Dir.chdir("#{source_root}/test")
10
10
  require 'rubygems'
11
11
  require 'json'
12
12
  begin
13
- CONFIG = JSON.load(File.read('config.json'))
13
+ CONFIG = JSON.load(File.read('config.json'))
14
14
  rescue Errno::ENOENT
15
- STDERR.puts "*** You do not have the file test/config.json. " <<
16
- "Please copy test/config.json.example to " <<
17
- "test/config.json, and edit it."
18
- exit 1
15
+ STDERR.puts "*** You do not have the file test/config.json. " <<
16
+ "Please copy test/config.json.example to " <<
17
+ "test/config.json, and edit it."
18
+ exit 1
19
19
  end
20
20
 
21
21
  def boolean_option(name, default_value = false)
22
- value = ENV[name]
23
- if value.nil? || value.empty?
24
- return default_value
25
- else
26
- return value == "yes" || value == "on" || value == "true" || value == "1"
27
- end
22
+ value = ENV[name]
23
+ if value.nil? || value.empty?
24
+ return default_value
25
+ else
26
+ return value == "yes" || value == "on" || value == "true" || value == "1"
27
+ end
28
28
  end
29
29
 
30
30
  DEBUG = boolean_option('DEBUG')
@@ -50,65 +50,65 @@ include TestHelper
50
50
  srand
51
51
 
52
52
  trap "QUIT" do
53
- STDERR.puts PhusionPassenger::Utils.global_backtrace_report
53
+ STDERR.puts PhusionPassenger::Utils.global_backtrace_report
54
54
  end
55
55
 
56
56
  class DeadlineTimer
57
- def initialize(main_thread, deadline)
58
- @mutex = Mutex.new
59
- @cond = ConditionVariable.new
60
- @iteration = 0
61
- @pipe = IO.pipe
62
-
63
- @thread = Thread.new do
64
- Thread.current.abort_on_exception = true
65
- expected_iteration = 1
66
- ios = [@pipe[0]]
67
- while true
68
- @mutex.synchronize do
69
- while @iteration != expected_iteration
70
- @cond.wait(@mutex)
71
- end
72
- end
73
- if !select(ios, nil, nil, deadline)
74
- STDERR.puts "*** Test timed out (#{deadline} seconds)"
75
- STDERR.puts PhusionPassenger::Utils.global_backtrace_report
76
- main_thread.raise(Timeout::Error, "Test timed out")
77
- expected_iteration += 1
78
- elsif @pipe[0].read(1).nil?
79
- break
80
- else
81
- expected_iteration += 1
82
- end
83
- end
84
- end
85
- end
86
-
87
- def start
88
- @mutex.synchronize do
89
- @iteration += 1
90
- @cond.signal
91
- end
92
- end
93
-
94
- def stop
95
- @pipe[1].write('x')
96
- end
57
+ def initialize(main_thread, deadline)
58
+ @mutex = Mutex.new
59
+ @cond = ConditionVariable.new
60
+ @iteration = 0
61
+ @pipe = IO.pipe
62
+
63
+ @thread = Thread.new do
64
+ Thread.current.abort_on_exception = true
65
+ expected_iteration = 1
66
+ ios = [@pipe[0]]
67
+ while true
68
+ @mutex.synchronize do
69
+ while @iteration != expected_iteration
70
+ @cond.wait(@mutex)
71
+ end
72
+ end
73
+ if !select(ios, nil, nil, deadline)
74
+ STDERR.puts "*** Test timed out (#{deadline} seconds)"
75
+ STDERR.puts PhusionPassenger::Utils.global_backtrace_report
76
+ main_thread.raise(Timeout::Error, "Test timed out")
77
+ expected_iteration += 1
78
+ elsif @pipe[0].read(1).nil?
79
+ break
80
+ else
81
+ expected_iteration += 1
82
+ end
83
+ end
84
+ end
85
+ end
86
+
87
+ def start
88
+ @mutex.synchronize do
89
+ @iteration += 1
90
+ @cond.signal
91
+ end
92
+ end
93
+
94
+ def stop
95
+ @pipe[1].write('x')
96
+ end
97
97
  end
98
98
 
99
99
  DEADLINE_TIMER = DeadlineTimer.new(Thread.current, 30)
100
100
 
101
101
  RSpec.configure do |config|
102
- config.before(:each) do
103
- # Suppress warning messages.
104
- PhusionPassenger::DebugLogging.log_level = PhusionPassenger::LVL_CRIT
105
- PhusionPassenger::DebugLogging.log_file = nil
106
- PhusionPassenger::DebugLogging.stderr_evaluator = nil
107
-
108
- DEADLINE_TIMER.start
109
- end
110
-
111
- config.after(:each) do
112
- DEADLINE_TIMER.stop
113
- end
102
+ config.before(:each) do
103
+ # Suppress warning messages.
104
+ PhusionPassenger::DebugLogging.log_level = PhusionPassenger::LVL_CRIT
105
+ PhusionPassenger::DebugLogging.log_file = nil
106
+ PhusionPassenger::DebugLogging.stderr_evaluator = nil
107
+
108
+ DEADLINE_TIMER.start
109
+ end
110
+
111
+ config.after(:each) do
112
+ DEADLINE_TIMER.stop
113
+ end
114
114
  end
@@ -11,390 +11,390 @@ module PhusionPassenger
11
11
  module Standalone
12
12
 
13
13
  describe RuntimeInstaller do
14
- before :each do
15
- @temp_dir = Dir.mktmpdir
16
- Dir.mkdir("#{@temp_dir}/support")
17
- Dir.mkdir("#{@temp_dir}/nginx")
18
- @logs = StringIO.new
19
- PhusionPassenger.stub(:installed_from_release_package?).and_return(true)
20
- end
21
-
22
- after :each do
23
- FileUtils.remove_entry_secure(@temp_dir)
24
- end
25
-
26
- let(:binaries_url_root) { "http://somewhere" }
27
- let(:version) { PhusionPassenger::VERSION_STRING }
28
- let(:nginx_version) { PhusionPassenger::PREFERRED_NGINX_VERSION }
29
- let(:cxx_compat_id) { PlatformInfo.cxx_binary_compatibility_id }
30
- let(:support_binaries_url) { "#{binaries_url_root}/#{version}/support-#{cxx_compat_id}.tar.gz" }
31
- let(:nginx_binary_url) { "#{binaries_url_root}/#{version}/webhelper-#{nginx_version}-#{cxx_compat_id}.tar.gz" }
32
- let(:nginx_source_url) { "http://nginx.org/download/nginx-#{nginx_version}.tar.gz" }
33
-
34
- def create_installer(options = {})
35
- options = {
36
- :binaries_url_root => binaries_url_root,
37
- :stdout => @logs,
38
- :stderr => @logs
39
- }.merge(options)
40
- @installer = RuntimeInstaller.new(options)
41
- end
42
-
43
- def create_tarball(filename, contents = nil)
44
- Dir.mktmpdir("tarball-", @temp_dir) do |tarball_dir|
45
- Dir.chdir(tarball_dir) do
46
- if block_given?
47
- yield
48
- else
49
- contents.each do |content_name|
50
- File.open(content_name, "w").close
51
- end
52
- end
53
- sh "tar", "-czf", filename, "."
54
- end
55
- end
56
- end
57
-
58
- def create_dummy_support_binaries
59
- Dir.mkdir("support-binaries")
60
- File.open("support-binaries/#{AGENT_EXE}", "w") do |f|
61
- f.puts "#!/bin/bash"
62
- f.puts "echo PASS"
63
- end
64
- File.chmod(0755, "support-binaries/#{AGENT_EXE}")
65
- end
66
-
67
- def create_dummy_nginx_binary
68
- File.open("PassengerWebHelper", "w") do |f|
69
- f.puts "#!/bin/bash"
70
- f.puts "echo nginx version: 1.0.0"
71
- end
72
- File.chmod(0755, "PassengerWebHelper")
73
- end
74
-
75
- def create_dummy_nginx_source
76
- Dir.mkdir("nginx-#{nginx_version}")
77
- File.open("nginx-#{nginx_version}/configure", "w") do |f|
78
- f.puts %Q{echo "$@" > '#{@temp_dir}/configure.txt'}
79
- end
80
- File.chmod(0700, "nginx-#{nginx_version}/configure")
81
- File.open("nginx-#{nginx_version}/Makefile", "w") do |f|
82
- f.puts("all:")
83
- f.puts(" mkdir objs")
84
- f.puts(" echo ok > objs/nginx")
85
- end
86
- end
87
-
88
- def create_file(filename)
89
- File.open(filename, "w").close
90
- end
91
-
92
- def sh(*command)
93
- if !system(*command)
94
- raise "Command failed: #{command.join(' ')}"
95
- end
96
- end
97
-
98
- def test_download_nginx_binary
99
- create_installer(:targets => [:nginx],
100
- :nginx_dir => "#{@temp_dir}/nginx",
101
- :lib_dir => PhusionPassenger.lib_dir)
102
-
103
- @installer.should_receive(:download).
104
- and_return do |url, output, options|
105
- url.should == nginx_binary_url
106
- options[:use_cache].should be_true
107
- create_tarball(output) do
108
- create_dummy_nginx_binary
109
- end
110
- true
111
- end
112
-
113
- @installer.should_receive(:check_for_download_tool)
114
- @installer.should_not_receive(:check_depdendencies)
115
- @installer.should_not_receive(:compile_support_binaries)
116
- @installer.should_not_receive(:download_and_extract_nginx_sources)
117
- @installer.should_not_receive(:compile_nginx)
118
- @installer.run
119
-
120
- File.exist?("#{@temp_dir}/nginx/PassengerWebHelper").should be_true
121
- end
122
-
123
- def test_building_nginx_binary
124
- create_installer(:targets => [:nginx],
125
- :nginx_dir => "#{@temp_dir}/nginx",
126
- :lib_dir => PhusionPassenger.lib_dir)
127
-
128
- @installer.should_receive(:download).twice.and_return do |url, output|
129
- if url == nginx_binary_url
130
- false
131
- elsif url == nginx_source_url
132
- create_tarball(output) do
133
- create_dummy_nginx_source
134
- end
135
- true
136
- else
137
- raise "Unexpected download URL: #{url}"
138
- end
139
- end
140
-
141
- @installer.should_receive(:check_for_download_tool)
142
- @installer.should_receive(:check_dependencies).and_return(true)
143
- @installer.should_not_receive(:compile_support_binaries)
144
- @installer.should_receive(:strip_binary).
145
- with(an_instance_of(String)).
146
- and_return(true)
147
- @installer.run
148
-
149
- File.read("#{@temp_dir}/nginx/PassengerWebHelper").should == "ok\n"
150
- File.read("#{@temp_dir}/configure.txt").should include(
151
- "--add-module=#{PhusionPassenger.nginx_module_source_dir}")
152
- end
153
-
154
- context "when originally packaged" do
155
- before :each do
156
- PhusionPassenger.stub(:originally_packaged?).and_return(true)
157
- PhusionPassenger.stub(:natively_packaged?).and_return(false)
158
- end
159
-
160
- it "downloads the support binaries from the Internet if :support_binaries is specified as target" do
161
- create_installer(:targets => [:support_binaries],
162
- :support_dir => "#{@temp_dir}/support")
163
-
164
- @installer.should_receive(:download).
165
- and_return do |url, output, options|
166
- url.should == "#{binaries_url_root}/#{version}/support-#{cxx_compat_id}.tar.gz"
167
- options[:use_cache].should be_true
168
- create_tarball(output) do
169
- create_dummy_support_binaries
170
- end
171
- true
172
- end
173
-
174
- @installer.should_receive(:check_for_download_tool)
175
- @installer.should_not_receive(:check_depdendencies)
176
- @installer.should_not_receive(:compile_support_binaries)
177
- @installer.should_not_receive(:download_and_extract_nginx_sources)
178
- @installer.should_not_receive(:compile_nginx)
179
- @installer.run
180
-
181
- File.exist?("#{@temp_dir}/support/support-binaries/#{AGENT_EXE}").should be_true
182
- end
183
-
184
- it "downloads the Nginx binary from the Internet if :nginx is specified as target" do
185
- test_download_nginx_binary
186
- end
187
-
188
- it "downloads everything if :support_binaries and :nginx are both specified as target" do
189
- create_installer(:targets => [:support_binaries, :nginx],
190
- :support_dir => "#{@temp_dir}/support",
191
- :nginx_dir => "#{@temp_dir}/nginx",
192
- :lib_dir => PhusionPassenger.lib_dir)
193
-
194
- @installer.should_receive(:download).
195
- twice.
196
- and_return do |url, output, options|
197
- if url == support_binaries_url
198
- create_tarball(output) do
199
- create_dummy_support_binaries
200
- end
201
- elsif url == nginx_binary_url
202
- create_tarball(output) do
203
- create_dummy_nginx_binary
204
- end
205
- else
206
- raise "Unexpected download URL: #{url}"
207
- end
208
- options[:use_cache].should be_true
209
- true
210
- end
211
-
212
- @installer.should_receive(:check_for_download_tool)
213
- @installer.should_not_receive(:check_depdendencies)
214
- @installer.should_not_receive(:compile_support_binaries)
215
- @installer.should_not_receive(:download_and_extract_nginx_sources)
216
- @installer.should_not_receive(:compile_nginx)
217
- @installer.run
218
-
219
- File.exist?("#{@temp_dir}/support/support-binaries/#{AGENT_EXE}").should be_true
220
- File.exist?("#{@temp_dir}/nginx/PassengerWebHelper").should be_true
221
- end
222
-
223
- it "builds the support binaries if it cannot be downloaded" do
224
- create_installer(:targets => [:support_binaries],
225
- :support_dir => "#{@temp_dir}/support")
226
- nginx_libs = COMMON_LIBRARY.
227
- only(*NGINX_LIBS_SELECTOR).
228
- set_output_dir("#{@temp_dir}/support/libpassenger_common").
229
- link_objects
230
- built_files = nil
231
-
232
- @installer.should_receive(:run_rake_task!).with(
233
- "nginx_without_native_support CACHING=false OUTPUT_DIR='#{@temp_dir}/support'").
234
- and_return do
235
- FileUtils.mkdir_p("#{@temp_dir}/support-binaries")
236
- create_file("#{@temp_dir}/support-binaries/#{AGENT_EXE}")
237
-
238
- nginx_libs.each do |object_filename|
239
- dir = File.dirname(object_filename)
240
- FileUtils.mkdir_p(dir)
241
- create_file(object_filename)
242
- end
243
-
244
- built_files = `find '#{@temp_dir}/support'`
245
- end
246
-
247
- @installer.should_receive(:check_for_download_tool)
248
- @installer.should_receive(:download).and_return(false)
249
- @installer.should_receive(:check_dependencies).and_return(true)
250
- @installer.should_not_receive(:download_and_extract_nginx_sources)
251
- @installer.should_not_receive(:compile_nginx)
252
- @installer.run
253
- `find '#{@temp_dir}/support'`.should == built_files
254
- end
255
-
256
- it "builds the Nginx binary if it cannot be downloaded" do
257
- test_building_nginx_binary
258
- end
259
-
260
- it "aborts if the support binaries cannot be built" do
261
- create_installer(:targets => [:support_binaries],
262
- :support_dir => "#{@temp_dir}/support")
263
-
264
- @installer.should_receive(:run_rake_task!).with(
265
- "nginx_without_native_support CACHING=false OUTPUT_DIR='#{@temp_dir}/support'").
266
- and_raise(RuntimeError, "Rake failed")
267
-
268
- @installer.should_receive(:check_for_download_tool)
269
- @installer.should_receive(:download).and_return(false)
270
- @installer.should_receive(:check_dependencies).and_return(true)
271
- @installer.should_not_receive(:download_and_extract_nginx_sources)
272
- @installer.should_not_receive(:compile_nginx)
273
- lambda { @installer.run }.should raise_error(SystemExit)
274
- @logs.string.should include("Rake failed")
275
- end
276
- end
277
-
278
- context "when natively packaged" do
279
- before :each do
280
- PhusionPassenger.stub(:source_root).and_return("/locations.ini")
281
- PhusionPassenger.stub(:originally_packaged?).and_return(false)
282
- PhusionPassenger.stub(:natively_packaged?).and_return(true)
283
- end
284
-
285
- it "refuses to accept :support_binaries as target" do
286
- block = lambda do
287
- create_installer(:targets => [:support_binaries],
288
- :support_dir => "#{@temp_dir}/support")
289
- end
290
- block.should raise_error(ArgumentError, /You cannot specify :support_binaries/)
291
- end
292
-
293
- it "downloads the Nginx binary from the Internet if :nginx is specified as target" do
294
- test_download_nginx_binary
295
- end
296
-
297
- it "builds the Nginx binary if it cannot be downloaded" do
298
- test_building_nginx_binary
299
- end
300
- end
301
-
302
- it "commits downloaded binaries after checking whether they're usable" do
303
- create_installer(:targets => [:support_binaries, :nginx],
304
- :support_dir => "#{@temp_dir}/support",
305
- :nginx_dir => "#{@temp_dir}/nginx",
306
- :lib_dir => PhusionPassenger.lib_dir)
307
-
308
- @installer.should_receive(:download).
309
- exactly(3).times.
310
- and_return do |url, output, options|
311
- if url == support_binaries_url
312
- options[:use_cache].should be_true
313
- create_tarball(output) do
314
- create_dummy_support_binaries
315
- end
316
- elsif url == nginx_binary_url
317
- options[:use_cache].should be_true
318
- create_tarball(output) do
319
- create_dummy_nginx_binary
320
- end
321
- elsif url == nginx_source_url
322
- create_tarball(output) do
323
- create_dummy_nginx_source
324
- end
325
- else
326
- raise "Unexpected download URL: #{url}"
327
- end
328
- true
329
- end
330
-
331
- @installer.should_receive(:check_for_download_tool)
332
- @installer.should_receive(:check_support_binaries).and_return(false)
333
- @installer.should_receive(:check_nginx_binary).and_return(false)
334
- @installer.should_receive(:check_dependencies).and_return(true)
335
- @installer.should_receive(:compile_support_binaries)
336
- @installer.should_receive(:compile_nginx)
337
- @installer.run
338
-
339
- Dir["#{@temp_dir}/nginx/*"].should be_empty
340
- Dir["#{@temp_dir}/support/*"].should be_empty
341
- end
342
-
343
- it "aborts if the Nginx source tarball cannot be extracted" do
344
- create_installer(:targets => [:nginx],
345
- :nginx_dir => "#{@temp_dir}/nginx",
346
- :lib_dir => PhusionPassenger.lib_dir)
347
-
348
- @installer.should_receive(:download).twice.and_return do |url, output, options|
349
- if url == nginx_binary_url
350
- false
351
- elsif url == nginx_source_url
352
- File.open(output, "w") do |f|
353
- f.write("garbage")
354
- end
355
- true
356
- else
357
- raise "Unexpected download URL: #{url}"
358
- end
359
- end
360
-
361
- @installer.should_receive(:check_for_download_tool)
362
- @installer.should_receive(:check_dependencies).and_return(true)
363
- @installer.should_not_receive(:compile_support_binaries)
364
- lambda { @installer.run }.should raise_error(SystemExit)
365
- @logs.string.should =~ %r{Unable to download or extract Nginx source tarball}
366
- end
367
-
368
- it "aborts if the Nginx binary cannot be built" do
369
- create_installer(:targets => [:nginx],
370
- :nginx_dir => "#{@temp_dir}/nginx",
371
- :lib_dir => PhusionPassenger.lib_dir)
372
-
373
- @installer.should_receive(:download).twice.and_return do |url, output, options|
374
- if url == nginx_binary_url
375
- false
376
- elsif url == nginx_source_url
377
- create_tarball(output) do
378
- Dir.mkdir("nginx-#{nginx_version}")
379
- File.open("nginx-#{nginx_version}/configure", "w") do |f|
380
- f.puts("#!/bin/bash")
381
- f.puts("echo error")
382
- f.puts("exit 1")
383
- end
384
- File.chmod(0700, "nginx-#{nginx_version}/configure")
385
- end
386
- true
387
- else
388
- raise "Unexpected download URL: #{url}"
389
- end
390
- end
391
-
392
- @installer.should_receive(:check_for_download_tool)
393
- @installer.should_receive(:check_dependencies).and_return(true)
394
- @installer.should_not_receive(:compile_support_binaries)
395
- lambda { @installer.run }.should raise_error(SystemExit)
396
- @logs.string.should =~ %r{command failed:.*./configure}
397
- end
14
+ before :each do
15
+ @temp_dir = Dir.mktmpdir
16
+ Dir.mkdir("#{@temp_dir}/support")
17
+ Dir.mkdir("#{@temp_dir}/nginx")
18
+ @logs = StringIO.new
19
+ PhusionPassenger.stub(:installed_from_release_package?).and_return(true)
20
+ end
21
+
22
+ after :each do
23
+ FileUtils.remove_entry_secure(@temp_dir)
24
+ end
25
+
26
+ let(:binaries_url_root) { "http://somewhere" }
27
+ let(:version) { PhusionPassenger::VERSION_STRING }
28
+ let(:nginx_version) { PhusionPassenger::PREFERRED_NGINX_VERSION }
29
+ let(:cxx_compat_id) { PlatformInfo.cxx_binary_compatibility_id }
30
+ let(:support_binaries_url) { "#{binaries_url_root}/#{version}/support-#{cxx_compat_id}.tar.gz" }
31
+ let(:nginx_binary_url) { "#{binaries_url_root}/#{version}/webhelper-#{nginx_version}-#{cxx_compat_id}.tar.gz" }
32
+ let(:nginx_source_url) { "http://nginx.org/download/nginx-#{nginx_version}.tar.gz" }
33
+
34
+ def create_installer(options = {})
35
+ options = {
36
+ :binaries_url_root => binaries_url_root,
37
+ :stdout => @logs,
38
+ :stderr => @logs
39
+ }.merge(options)
40
+ @installer = RuntimeInstaller.new(options)
41
+ end
42
+
43
+ def create_tarball(filename, contents = nil)
44
+ Dir.mktmpdir("tarball-", @temp_dir) do |tarball_dir|
45
+ Dir.chdir(tarball_dir) do
46
+ if block_given?
47
+ yield
48
+ else
49
+ contents.each do |content_name|
50
+ File.open(content_name, "w").close
51
+ end
52
+ end
53
+ sh "tar", "-czf", filename, "."
54
+ end
55
+ end
56
+ end
57
+
58
+ def create_dummy_support_binaries
59
+ Dir.mkdir("support-binaries")
60
+ File.open("support-binaries/#{AGENT_EXE}", "w") do |f|
61
+ f.puts "#!/bin/bash"
62
+ f.puts "echo PASS"
63
+ end
64
+ File.chmod(0755, "support-binaries/#{AGENT_EXE}")
65
+ end
66
+
67
+ def create_dummy_nginx_binary
68
+ File.open("PassengerWebHelper", "w") do |f|
69
+ f.puts "#!/bin/bash"
70
+ f.puts "echo nginx version: 1.0.0"
71
+ end
72
+ File.chmod(0755, "PassengerWebHelper")
73
+ end
74
+
75
+ def create_dummy_nginx_source
76
+ Dir.mkdir("nginx-#{nginx_version}")
77
+ File.open("nginx-#{nginx_version}/configure", "w") do |f|
78
+ f.puts %Q{echo "$@" > '#{@temp_dir}/configure.txt'}
79
+ end
80
+ File.chmod(0700, "nginx-#{nginx_version}/configure")
81
+ File.open("nginx-#{nginx_version}/Makefile", "w") do |f|
82
+ f.puts("all:")
83
+ f.puts(" mkdir objs")
84
+ f.puts(" echo ok > objs/nginx")
85
+ end
86
+ end
87
+
88
+ def create_file(filename)
89
+ File.open(filename, "w").close
90
+ end
91
+
92
+ def sh(*command)
93
+ if !system(*command)
94
+ raise "Command failed: #{command.join(' ')}"
95
+ end
96
+ end
97
+
98
+ def test_download_nginx_binary
99
+ create_installer(:targets => [:nginx],
100
+ :nginx_dir => "#{@temp_dir}/nginx",
101
+ :lib_dir => PhusionPassenger.lib_dir)
102
+
103
+ @installer.should_receive(:download).
104
+ and_return do |url, output, options|
105
+ url.should == nginx_binary_url
106
+ options[:use_cache].should be_true
107
+ create_tarball(output) do
108
+ create_dummy_nginx_binary
109
+ end
110
+ true
111
+ end
112
+
113
+ @installer.should_receive(:check_for_download_tool)
114
+ @installer.should_not_receive(:check_depdendencies)
115
+ @installer.should_not_receive(:compile_support_binaries)
116
+ @installer.should_not_receive(:download_and_extract_nginx_sources)
117
+ @installer.should_not_receive(:compile_nginx)
118
+ @installer.run
119
+
120
+ File.exist?("#{@temp_dir}/nginx/PassengerWebHelper").should be_true
121
+ end
122
+
123
+ def test_building_nginx_binary
124
+ create_installer(:targets => [:nginx],
125
+ :nginx_dir => "#{@temp_dir}/nginx",
126
+ :lib_dir => PhusionPassenger.lib_dir)
127
+
128
+ @installer.should_receive(:download).twice.and_return do |url, output|
129
+ if url == nginx_binary_url
130
+ false
131
+ elsif url == nginx_source_url
132
+ create_tarball(output) do
133
+ create_dummy_nginx_source
134
+ end
135
+ true
136
+ else
137
+ raise "Unexpected download URL: #{url}"
138
+ end
139
+ end
140
+
141
+ @installer.should_receive(:check_for_download_tool)
142
+ @installer.should_receive(:check_dependencies).and_return(true)
143
+ @installer.should_not_receive(:compile_support_binaries)
144
+ @installer.should_receive(:strip_binary).
145
+ with(an_instance_of(String)).
146
+ and_return(true)
147
+ @installer.run
148
+
149
+ File.read("#{@temp_dir}/nginx/PassengerWebHelper").should == "ok\n"
150
+ File.read("#{@temp_dir}/configure.txt").should include(
151
+ "--add-module=#{PhusionPassenger.nginx_module_source_dir}")
152
+ end
153
+
154
+ context "when originally packaged" do
155
+ before :each do
156
+ PhusionPassenger.stub(:originally_packaged?).and_return(true)
157
+ PhusionPassenger.stub(:natively_packaged?).and_return(false)
158
+ end
159
+
160
+ it "downloads the support binaries from the Internet if :support_binaries is specified as target" do
161
+ create_installer(:targets => [:support_binaries],
162
+ :support_dir => "#{@temp_dir}/support")
163
+
164
+ @installer.should_receive(:download).
165
+ and_return do |url, output, options|
166
+ url.should == "#{binaries_url_root}/#{version}/support-#{cxx_compat_id}.tar.gz"
167
+ options[:use_cache].should be_true
168
+ create_tarball(output) do
169
+ create_dummy_support_binaries
170
+ end
171
+ true
172
+ end
173
+
174
+ @installer.should_receive(:check_for_download_tool)
175
+ @installer.should_not_receive(:check_depdendencies)
176
+ @installer.should_not_receive(:compile_support_binaries)
177
+ @installer.should_not_receive(:download_and_extract_nginx_sources)
178
+ @installer.should_not_receive(:compile_nginx)
179
+ @installer.run
180
+
181
+ File.exist?("#{@temp_dir}/support/support-binaries/#{AGENT_EXE}").should be_true
182
+ end
183
+
184
+ it "downloads the Nginx binary from the Internet if :nginx is specified as target" do
185
+ test_download_nginx_binary
186
+ end
187
+
188
+ it "downloads everything if :support_binaries and :nginx are both specified as target" do
189
+ create_installer(:targets => [:support_binaries, :nginx],
190
+ :support_dir => "#{@temp_dir}/support",
191
+ :nginx_dir => "#{@temp_dir}/nginx",
192
+ :lib_dir => PhusionPassenger.lib_dir)
193
+
194
+ @installer.should_receive(:download).
195
+ twice.
196
+ and_return do |url, output, options|
197
+ if url == support_binaries_url
198
+ create_tarball(output) do
199
+ create_dummy_support_binaries
200
+ end
201
+ elsif url == nginx_binary_url
202
+ create_tarball(output) do
203
+ create_dummy_nginx_binary
204
+ end
205
+ else
206
+ raise "Unexpected download URL: #{url}"
207
+ end
208
+ options[:use_cache].should be_true
209
+ true
210
+ end
211
+
212
+ @installer.should_receive(:check_for_download_tool)
213
+ @installer.should_not_receive(:check_depdendencies)
214
+ @installer.should_not_receive(:compile_support_binaries)
215
+ @installer.should_not_receive(:download_and_extract_nginx_sources)
216
+ @installer.should_not_receive(:compile_nginx)
217
+ @installer.run
218
+
219
+ File.exist?("#{@temp_dir}/support/support-binaries/#{AGENT_EXE}").should be_true
220
+ File.exist?("#{@temp_dir}/nginx/PassengerWebHelper").should be_true
221
+ end
222
+
223
+ it "builds the support binaries if it cannot be downloaded" do
224
+ create_installer(:targets => [:support_binaries],
225
+ :support_dir => "#{@temp_dir}/support")
226
+ nginx_libs = COMMON_LIBRARY.
227
+ only(*NGINX_LIBS_SELECTOR).
228
+ set_output_dir("#{@temp_dir}/support/libpassenger_common").
229
+ link_objects
230
+ built_files = nil
231
+
232
+ @installer.should_receive(:run_rake_task!).with(
233
+ "nginx_without_native_support CACHING=false OUTPUT_DIR='#{@temp_dir}/support'").
234
+ and_return do
235
+ FileUtils.mkdir_p("#{@temp_dir}/support-binaries")
236
+ create_file("#{@temp_dir}/support-binaries/#{AGENT_EXE}")
237
+
238
+ nginx_libs.each do |object_filename|
239
+ dir = File.dirname(object_filename)
240
+ FileUtils.mkdir_p(dir)
241
+ create_file(object_filename)
242
+ end
243
+
244
+ built_files = `find '#{@temp_dir}/support'`
245
+ end
246
+
247
+ @installer.should_receive(:check_for_download_tool)
248
+ @installer.should_receive(:download).and_return(false)
249
+ @installer.should_receive(:check_dependencies).and_return(true)
250
+ @installer.should_not_receive(:download_and_extract_nginx_sources)
251
+ @installer.should_not_receive(:compile_nginx)
252
+ @installer.run
253
+ `find '#{@temp_dir}/support'`.should == built_files
254
+ end
255
+
256
+ it "builds the Nginx binary if it cannot be downloaded" do
257
+ test_building_nginx_binary
258
+ end
259
+
260
+ it "aborts if the support binaries cannot be built" do
261
+ create_installer(:targets => [:support_binaries],
262
+ :support_dir => "#{@temp_dir}/support")
263
+
264
+ @installer.should_receive(:run_rake_task!).with(
265
+ "nginx_without_native_support CACHING=false OUTPUT_DIR='#{@temp_dir}/support'").
266
+ and_raise(RuntimeError, "Rake failed")
267
+
268
+ @installer.should_receive(:check_for_download_tool)
269
+ @installer.should_receive(:download).and_return(false)
270
+ @installer.should_receive(:check_dependencies).and_return(true)
271
+ @installer.should_not_receive(:download_and_extract_nginx_sources)
272
+ @installer.should_not_receive(:compile_nginx)
273
+ lambda { @installer.run }.should raise_error(SystemExit)
274
+ @logs.string.should include("Rake failed")
275
+ end
276
+ end
277
+
278
+ context "when natively packaged" do
279
+ before :each do
280
+ PhusionPassenger.stub(:source_root).and_return("/locations.ini")
281
+ PhusionPassenger.stub(:originally_packaged?).and_return(false)
282
+ PhusionPassenger.stub(:natively_packaged?).and_return(true)
283
+ end
284
+
285
+ it "refuses to accept :support_binaries as target" do
286
+ block = lambda do
287
+ create_installer(:targets => [:support_binaries],
288
+ :support_dir => "#{@temp_dir}/support")
289
+ end
290
+ block.should raise_error(ArgumentError, /You cannot specify :support_binaries/)
291
+ end
292
+
293
+ it "downloads the Nginx binary from the Internet if :nginx is specified as target" do
294
+ test_download_nginx_binary
295
+ end
296
+
297
+ it "builds the Nginx binary if it cannot be downloaded" do
298
+ test_building_nginx_binary
299
+ end
300
+ end
301
+
302
+ it "commits downloaded binaries after checking whether they're usable" do
303
+ create_installer(:targets => [:support_binaries, :nginx],
304
+ :support_dir => "#{@temp_dir}/support",
305
+ :nginx_dir => "#{@temp_dir}/nginx",
306
+ :lib_dir => PhusionPassenger.lib_dir)
307
+
308
+ @installer.should_receive(:download).
309
+ exactly(3).times.
310
+ and_return do |url, output, options|
311
+ if url == support_binaries_url
312
+ options[:use_cache].should be_true
313
+ create_tarball(output) do
314
+ create_dummy_support_binaries
315
+ end
316
+ elsif url == nginx_binary_url
317
+ options[:use_cache].should be_true
318
+ create_tarball(output) do
319
+ create_dummy_nginx_binary
320
+ end
321
+ elsif url == nginx_source_url
322
+ create_tarball(output) do
323
+ create_dummy_nginx_source
324
+ end
325
+ else
326
+ raise "Unexpected download URL: #{url}"
327
+ end
328
+ true
329
+ end
330
+
331
+ @installer.should_receive(:check_for_download_tool)
332
+ @installer.should_receive(:check_support_binaries).and_return(false)
333
+ @installer.should_receive(:check_nginx_binary).and_return(false)
334
+ @installer.should_receive(:check_dependencies).and_return(true)
335
+ @installer.should_receive(:compile_support_binaries)
336
+ @installer.should_receive(:compile_nginx)
337
+ @installer.run
338
+
339
+ Dir["#{@temp_dir}/nginx/*"].should be_empty
340
+ Dir["#{@temp_dir}/support/*"].should be_empty
341
+ end
342
+
343
+ it "aborts if the Nginx source tarball cannot be extracted" do
344
+ create_installer(:targets => [:nginx],
345
+ :nginx_dir => "#{@temp_dir}/nginx",
346
+ :lib_dir => PhusionPassenger.lib_dir)
347
+
348
+ @installer.should_receive(:download).twice.and_return do |url, output, options|
349
+ if url == nginx_binary_url
350
+ false
351
+ elsif url == nginx_source_url
352
+ File.open(output, "w") do |f|
353
+ f.write("garbage")
354
+ end
355
+ true
356
+ else
357
+ raise "Unexpected download URL: #{url}"
358
+ end
359
+ end
360
+
361
+ @installer.should_receive(:check_for_download_tool)
362
+ @installer.should_receive(:check_dependencies).and_return(true)
363
+ @installer.should_not_receive(:compile_support_binaries)
364
+ lambda { @installer.run }.should raise_error(SystemExit)
365
+ @logs.string.should =~ %r{Unable to download or extract Nginx source tarball}
366
+ end
367
+
368
+ it "aborts if the Nginx binary cannot be built" do
369
+ create_installer(:targets => [:nginx],
370
+ :nginx_dir => "#{@temp_dir}/nginx",
371
+ :lib_dir => PhusionPassenger.lib_dir)
372
+
373
+ @installer.should_receive(:download).twice.and_return do |url, output, options|
374
+ if url == nginx_binary_url
375
+ false
376
+ elsif url == nginx_source_url
377
+ create_tarball(output) do
378
+ Dir.mkdir("nginx-#{nginx_version}")
379
+ File.open("nginx-#{nginx_version}/configure", "w") do |f|
380
+ f.puts("#!/bin/bash")
381
+ f.puts("echo error")
382
+ f.puts("exit 1")
383
+ end
384
+ File.chmod(0700, "nginx-#{nginx_version}/configure")
385
+ end
386
+ true
387
+ else
388
+ raise "Unexpected download URL: #{url}"
389
+ end
390
+ end
391
+
392
+ @installer.should_receive(:check_for_download_tool)
393
+ @installer.should_receive(:check_dependencies).and_return(true)
394
+ @installer.should_not_receive(:compile_support_binaries)
395
+ lambda { @installer.run }.should raise_error(SystemExit)
396
+ @logs.string.should =~ %r{command failed:.*./configure}
397
+ end
398
398
  end
399
399
 
400
400
  end # module Standalone