rack.git  about / heads / tags
a modular Ruby webserver interface
blob d9926fda0f054a9cfe0c5b38c81524d17981c85b 3667 bytes (raw)
$ git show rack.io:test/spec_rackup.rb	# shows this blob on the CLI

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
 
require 'test/spec'
require 'testrequest'
require 'rack/server'
require 'open3'

begin
require "mongrel"

context "rackup" do
  include TestRequest::Helpers

  def run_rackup(*args)
    options = args.last.is_a?(Hash) ? args.pop : {}
    flags   = args.first
    @host = options[:host] || "0.0.0.0"
    @port = options[:port] || 9292

    Dir.chdir("#{root}/test/rackup") do
      @in, @rackup, @err = Open3.popen3("#{Gem.ruby} -S #{rackup} #{flags}")
    end

    return if options[:port] == false

    # Wait until the server is available
    begin
      GET("/")
    rescue
      sleep 0.05
      retry
    end
  end

  def output
    @rackup.read
  end

  after do
    # This doesn't actually return a response, so we rescue
    GET "/die" rescue nil

    Dir["#{root}/**/*.pid"].each do |file|
      File.delete(file)
    end

    File.delete("#{root}/log_output") if File.exist?("#{root}/log_output")
  end

  specify "rackup" do
    run_rackup
    response["PATH_INFO"].should.equal '/'
    response["test.$DEBUG"].should.be false
    response["test.$EVAL"].should.be nil
    response["test.$VERBOSE"].should.be false
    response["test.Ping"].should.be nil
    response["SERVER_SOFTWARE"].should.not =~ /webrick/
  end

  specify "rackup --help" do
    run_rackup "--help", :port => false
    output.should.match /--port/
  end

  specify "rackup --port" do
    run_rackup "--port 9000", :port => 9000
    response["SERVER_PORT"].should.equal "9000"
  end

  specify "rackup --debug" do
    run_rackup "--debug"
    response["test.$DEBUG"].should.be true
  end

  specify "rackup --eval" do
    run_rackup %{--eval "BUKKIT = 'BUKKIT'"}
    response["test.$EVAL"].should.equal "BUKKIT"
  end

  specify "rackup --warn" do
    run_rackup %{--warn}
    response["test.$VERBOSE"].should.be true
  end

  specify "rackup --include" do
    run_rackup %{--include /foo/bar}
    response["test.$LOAD_PATH"].should.include "/foo/bar"
  end

  specify "rackup --require" do
    run_rackup %{--require ping}
    response["test.Ping"].should.equal "constant"
  end

  specify "rackup --server" do
    run_rackup %{--server webrick}
    response["SERVER_SOFTWARE"].should =~ /webrick/i
  end

  specify "rackup --host" do
    run_rackup %{--host 127.0.0.1}, :host => "127.0.0.1"
    response["REMOTE_ADDR"].should.equal "127.0.0.1"
  end

  specify "rackup --daemonize --pid" do
    run_rackup %{--daemonize --pid testing.pid}
    status.should.be 200
    @rackup.should.be.eof?
    Dir["#{root}/**/testing.pid"].should.not.be.empty?
  end

  specify "rackup --pid" do
    run_rackup %{--pid testing.pid}
    status.should.be 200
    Dir["#{root}/**/testing.pid"].should.not.be.empty?
  end

  specify "rackup --version" do
    run_rackup %{--version}, :port => false
    output.should =~ /1.0/
  end

  specify "rackup --env development includes lint" do
    run_rackup
    GET("/broken_lint")
    status.should.be 500
  end

  specify "rackup --env deployment does not include lint" do
    run_rackup %{--env deployment}
    GET("/broken_lint")
    status.should.be 200
  end

  specify "rackup --env none does not include lint" do
    run_rackup %{--env none}
    GET("/broken_lint")
    status.should.be 200
  end

  specify "rackup --env deployment does log" do
    run_rackup %{--env deployment}
    log = File.read(response["test.stderr"])
    log.should.be.empty?
  end

  specify "rackup --env none does not log" do
    run_rackup %{--env none}
    GET("/")
    log = File.read(response["test.stderr"])
    log.should.be.empty?
  end
end
rescue LoadError
  $stderr.puts "Skipping rackup --server tests (mongrel is required). `gem install thin` and try again."
end

git clone https://yhbt.net/rack.git