Sha256: acf33a70cc1949216ba59df6c58b39ab01a0ad6f8b7eea533bb0b09ec8ecb19f

Contents?: true

Size: 1.21 KB

Versions: 6

Compression:

Stored size: 1.21 KB

Contents

require File.expand_path(File.dirname(__FILE__) + '/../spec_helper')
require 'ruby/shared/loader_sharedspec'
require 'ruby/shared/ruby_loader_sharedspec'

module PhusionPassenger

describe "Rack loader" do
  include LoaderSpecHelper

  before :each do
    @stub = register_stub(RackStub.new("rack"))
  end

  def start(options = {})
    @loader = Loader.new(["ruby", "#{PhusionPassenger.helper_scripts_dir}/rack-loader.rb"], @stub.app_root)
    return @loader.start(options)
  end

  it_should_behave_like "a loader"
  it_should_behave_like "a Ruby loader"

  it "calls the starting_worker_process event with forked=false" do
    File.prepend(@stub.startup_file, %q{
      history_file = "history.txt"
      PhusionPassenger.on_event(:starting_worker_process) do |forked|
        ::File.open(history_file, 'a') do |f|
          f.puts "worker_process_started: forked=#{forked}\n"
        end
      end
      ::File.open(history_file, 'a') do |f|
        f.puts "end of startup file\n"
      end
    })
    result = start
    result[:status].should == "Ready"
    File.read("#{@stub.app_root}/history.txt").should ==
      "end of startup file\n" +
      "worker_process_started: forked=false\n"
  end
end

end # module PhusionPassenger

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
passenger-5.0.4 test/ruby/rack/loader_spec.rb
passenger-5.0.3 test/ruby/rack/loader_spec.rb
passenger-5.0.2 test/ruby/rack/loader_spec.rb
passenger-5.0.1 test/ruby/rack/loader_spec.rb
passenger-5.0.0.rc2 test/ruby/rack/loader_spec.rb
passenger-5.0.0.rc1 test/ruby/rack/loader_spec.rb