Vendor Rack 1.0.1
Incorporate patch from Revision 496.
This commit is contained in:
parent
a7202d54cd
commit
76f388f3e2
113 changed files with 5759 additions and 199 deletions
172
vendor/plugins/rack/test/spec_rack_session_pool.rb
vendored
Normal file
172
vendor/plugins/rack/test/spec_rack_session_pool.rb
vendored
Normal file
|
@ -0,0 +1,172 @@
|
|||
require 'test/spec'
|
||||
|
||||
require 'rack/session/pool'
|
||||
require 'rack/mock'
|
||||
require 'rack/response'
|
||||
require 'thread'
|
||||
|
||||
context "Rack::Session::Pool" do
|
||||
session_key = Rack::Session::Pool::DEFAULT_OPTIONS[:key]
|
||||
session_match = /#{session_key}=[0-9a-fA-F]+;/
|
||||
incrementor = lambda do |env|
|
||||
env["rack.session"]["counter"] ||= 0
|
||||
env["rack.session"]["counter"] += 1
|
||||
Rack::Response.new(env["rack.session"].inspect).to_a
|
||||
end
|
||||
drop_session = proc do |env|
|
||||
env['rack.session.options'][:drop] = true
|
||||
incrementor.call(env)
|
||||
end
|
||||
renew_session = proc do |env|
|
||||
env['rack.session.options'][:renew] = true
|
||||
incrementor.call(env)
|
||||
end
|
||||
defer_session = proc do |env|
|
||||
env['rack.session.options'][:defer] = true
|
||||
incrementor.call(env)
|
||||
end
|
||||
|
||||
specify "creates a new cookie" do
|
||||
pool = Rack::Session::Pool.new(incrementor)
|
||||
res = Rack::MockRequest.new(pool).get("/")
|
||||
res["Set-Cookie"].should.match session_match
|
||||
res.body.should.equal '{"counter"=>1}'
|
||||
end
|
||||
|
||||
specify "determines session from a cookie" do
|
||||
pool = Rack::Session::Pool.new(incrementor)
|
||||
req = Rack::MockRequest.new(pool)
|
||||
cookie = req.get("/")["Set-Cookie"]
|
||||
req.get("/", "HTTP_COOKIE" => cookie).
|
||||
body.should.equal '{"counter"=>2}'
|
||||
req.get("/", "HTTP_COOKIE" => cookie).
|
||||
body.should.equal '{"counter"=>3}'
|
||||
end
|
||||
|
||||
specify "survives nonexistant cookies" do
|
||||
pool = Rack::Session::Pool.new(incrementor)
|
||||
res = Rack::MockRequest.new(pool).
|
||||
get("/", "HTTP_COOKIE" => "#{session_key}=blarghfasel")
|
||||
res.body.should.equal '{"counter"=>1}'
|
||||
end
|
||||
|
||||
specify "deletes cookies with :drop option" do
|
||||
pool = Rack::Session::Pool.new(incrementor)
|
||||
req = Rack::MockRequest.new(pool)
|
||||
drop = Rack::Utils::Context.new(pool, drop_session)
|
||||
dreq = Rack::MockRequest.new(drop)
|
||||
|
||||
res0 = req.get("/")
|
||||
session = (cookie = res0["Set-Cookie"])[session_match]
|
||||
res0.body.should.equal '{"counter"=>1}'
|
||||
pool.pool.size.should.be 1
|
||||
|
||||
res1 = req.get("/", "HTTP_COOKIE" => cookie)
|
||||
res1["Set-Cookie"][session_match].should.equal session
|
||||
res1.body.should.equal '{"counter"=>2}'
|
||||
pool.pool.size.should.be 1
|
||||
|
||||
res2 = dreq.get("/", "HTTP_COOKIE" => cookie)
|
||||
res2["Set-Cookie"].should.equal nil
|
||||
res2.body.should.equal '{"counter"=>3}'
|
||||
pool.pool.size.should.be 0
|
||||
|
||||
res3 = req.get("/", "HTTP_COOKIE" => cookie)
|
||||
res3["Set-Cookie"][session_match].should.not.equal session
|
||||
res3.body.should.equal '{"counter"=>1}'
|
||||
pool.pool.size.should.be 1
|
||||
end
|
||||
|
||||
specify "provides new session id with :renew option" do
|
||||
pool = Rack::Session::Pool.new(incrementor)
|
||||
req = Rack::MockRequest.new(pool)
|
||||
renew = Rack::Utils::Context.new(pool, renew_session)
|
||||
rreq = Rack::MockRequest.new(renew)
|
||||
|
||||
res0 = req.get("/")
|
||||
session = (cookie = res0["Set-Cookie"])[session_match]
|
||||
res0.body.should.equal '{"counter"=>1}'
|
||||
pool.pool.size.should.be 1
|
||||
|
||||
res1 = req.get("/", "HTTP_COOKIE" => cookie)
|
||||
res1["Set-Cookie"][session_match].should.equal session
|
||||
res1.body.should.equal '{"counter"=>2}'
|
||||
pool.pool.size.should.be 1
|
||||
|
||||
res2 = rreq.get("/", "HTTP_COOKIE" => cookie)
|
||||
new_cookie = res2["Set-Cookie"]
|
||||
new_session = new_cookie[session_match]
|
||||
new_session.should.not.equal session
|
||||
res2.body.should.equal '{"counter"=>3}'
|
||||
pool.pool.size.should.be 1
|
||||
|
||||
res3 = req.get("/", "HTTP_COOKIE" => new_cookie)
|
||||
res3["Set-Cookie"][session_match].should.equal new_session
|
||||
res3.body.should.equal '{"counter"=>4}'
|
||||
pool.pool.size.should.be 1
|
||||
end
|
||||
|
||||
specify "omits cookie with :defer option" do
|
||||
pool = Rack::Session::Pool.new(incrementor)
|
||||
req = Rack::MockRequest.new(pool)
|
||||
defer = Rack::Utils::Context.new(pool, defer_session)
|
||||
dreq = Rack::MockRequest.new(defer)
|
||||
|
||||
res0 = req.get("/")
|
||||
session = (cookie = res0["Set-Cookie"])[session_match]
|
||||
res0.body.should.equal '{"counter"=>1}'
|
||||
pool.pool.size.should.be 1
|
||||
|
||||
res1 = req.get("/", "HTTP_COOKIE" => cookie)
|
||||
res1["Set-Cookie"][session_match].should.equal session
|
||||
res1.body.should.equal '{"counter"=>2}'
|
||||
pool.pool.size.should.be 1
|
||||
|
||||
res2 = dreq.get("/", "HTTP_COOKIE" => cookie)
|
||||
res2["Set-Cookie"].should.equal nil
|
||||
res2.body.should.equal '{"counter"=>3}'
|
||||
pool.pool.size.should.be 1
|
||||
|
||||
res3 = req.get("/", "HTTP_COOKIE" => cookie)
|
||||
res3["Set-Cookie"][session_match].should.equal session
|
||||
res3.body.should.equal '{"counter"=>4}'
|
||||
pool.pool.size.should.be 1
|
||||
end
|
||||
|
||||
# anyone know how to do this better?
|
||||
specify "multithread: should merge sessions" do
|
||||
next unless $DEBUG
|
||||
warn 'Running multithread tests for Session::Pool'
|
||||
pool = Rack::Session::Pool.new(incrementor)
|
||||
req = Rack::MockRequest.new(pool)
|
||||
|
||||
res = req.get('/')
|
||||
res.body.should.equal '{"counter"=>1}'
|
||||
cookie = res["Set-Cookie"]
|
||||
sess_id = cookie[/#{pool.key}=([^,;]+)/,1]
|
||||
|
||||
delta_incrementor = lambda do |env|
|
||||
# emulate disconjoinment of threading
|
||||
env['rack.session'] = env['rack.session'].dup
|
||||
Thread.stop
|
||||
env['rack.session'][(Time.now.usec*rand).to_i] = true
|
||||
incrementor.call(env)
|
||||
end
|
||||
tses = Rack::Utils::Context.new pool, delta_incrementor
|
||||
treq = Rack::MockRequest.new(tses)
|
||||
tnum = rand(7).to_i+5
|
||||
r = Array.new(tnum) do
|
||||
Thread.new(treq) do |run|
|
||||
run.get('/', "HTTP_COOKIE" => cookie, 'rack.multithread' => true)
|
||||
end
|
||||
end.reverse.map{|t| t.run.join.value }
|
||||
r.each do |res|
|
||||
res['Set-Cookie'].should.equal cookie
|
||||
res.body.should.include '"counter"=>2'
|
||||
end
|
||||
|
||||
session = pool.pool[sess_id]
|
||||
session.size.should.be tnum+1 # counter
|
||||
session['counter'].should.be 2 # meeeh
|
||||
end
|
||||
end
|
Loading…
Add table
Add a link
Reference in a new issue