PHP 8.2.31
Preview: spec_commonlogger.rb Size: 2.37 KB
/proc/thread-self/root/opt/alt/ruby23/lib64/ruby/gems/2.3.0/gems/rack-1.6.4/test/spec_commonlogger.rb

require 'rack/commonlogger'
require 'rack/lint'
require 'rack/mock'

require 'logger'

describe Rack::CommonLogger do
  obj = 'foobar'
  length = obj.size

  app = Rack::Lint.new lambda { |env|
    [200,
     {"Content-Type" => "text/html", "Content-Length" => length.to_s},
     [obj]]}
  app_without_length = Rack::Lint.new lambda { |env|
    [200,
     {"Content-Type" => "text/html"},
     []]}
  app_with_zero_length = Rack::Lint.new lambda { |env|
    [200,
     {"Content-Type" => "text/html", "Content-Length" => "0"},
     []]}

  should "log to rack.errors by default" do
    res = Rack::MockRequest.new(Rack::CommonLogger.new(app)).get("/")

    res.errors.should.not.be.empty
    res.errors.should =~ /"GET \/ " 200 #{length} /
  end

  should "log to anything with +write+" do
    log = StringIO.new
    Rack::MockRequest.new(Rack::CommonLogger.new(app, log)).get("/")

    log.string.should =~ /"GET \/ " 200 #{length} /
  end

  should "work with standartd library logger" do
    logdev = StringIO.new
    log = Logger.new(logdev)
    Rack::MockRequest.new(Rack::CommonLogger.new(app, log)).get("/")

    logdev.string.should =~ /"GET \/ " 200 #{length} /
  end

  should "log - content length if header is missing" do
    res = Rack::MockRequest.new(Rack::CommonLogger.new(app_without_length)).get("/")

    res.errors.should.not.be.empty
    res.errors.should =~ /"GET \/ " 200 - /
  end

  should "log - content length if header is zero" do
    res = Rack::MockRequest.new(Rack::CommonLogger.new(app_with_zero_length)).get("/")

    res.errors.should.not.be.empty
    res.errors.should =~ /"GET \/ " 200 - /
  end

  def with_mock_time(t = 0)
    mc = class <<Time; self; end
    mc.send :alias_method, :old_now, :now
    mc.send :define_method, :now do
      at(t)
    end
    yield
  ensure
    mc.send :alias_method, :now, :old_now
  end

  should "log in common log format" do
    log = StringIO.new
    with_mock_time do
      Rack::MockRequest.new(Rack::CommonLogger.new(app, log)).get("/")
    end

    md = /- - - \[([^\]]+)\] "(\w+) \/ " (\d{3}) \d+ ([\d\.]+)/.match(log.string)
    md.should.not.equal nil
    time, method, status, duration = *md.captures
    time.should.equal Time.at(0).strftime("%d/%b/%Y:%H:%M:%S %z")
    method.should.equal "GET"
    status.should.equal "200"
    (0..1).should.include?(duration.to_f)
  end

  def length
    123
  end

  def self.obj
    "hello world"
  end
end

Directory Contents

Dirs: 7 × Files: 51

Name Size Perms Modified Actions
builder DIR
- drwxr-xr-x 2024-03-03 22:53:12
Edit Download
cgi DIR
- drwxr-xr-x 2024-03-03 22:53:12
Edit Download
multipart DIR
- drwxr-xr-x 2024-03-03 22:53:12
Edit Download
rackup DIR
- drwxr-xr-x 2024-03-03 22:53:12
Edit Download
- drwxr-xr-x 2024-03-03 22:53:12
Edit Download
static DIR
- drwxr-xr-x 2024-03-03 22:53:12
Edit Download
- drwxr-xr-x 2024-03-03 22:53:12
Edit Download
298 B lrw-r--r-- 2019-12-05 23:22:18
Edit Download
2.26 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
8.08 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
2.20 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
6.20 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
2.11 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
2.92 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
3.87 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
2.37 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
3.28 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
544 B lrw-r--r-- 2019-12-05 23:22:18
Edit Download
2.80 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
1.47 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
10.04 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
2.19 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
3.84 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
3.08 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
6.32 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
1.87 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
1.36 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
19.23 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
1.23 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
4.33 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
622 B lrw-r--r-- 2019-12-05 23:22:18
Edit Download
2.38 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
1.81 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
9.34 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
5.73 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
23.62 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
514 B lrw-r--r-- 2019-12-05 23:22:18
Edit Download
1.83 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
42.52 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
10.08 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
2.78 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
1.53 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
4.12 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
5.57 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
1.29 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
12.94 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
11.12 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
6.53 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
2.01 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
2.74 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
4.60 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
1.57 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
2.55 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
8.82 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
24.89 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
504 B lrw-r--r-- 2019-12-05 23:22:18
Edit Download
5.50 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download
1.96 KB lrw-r--r-- 2019-12-05 23:22:18
Edit Download

If ZipArchive is unavailable, a .tar will be created (no compression).