Bugfixes and Rails Edge
Update to Rails 2.3.1. (Actually, not quite. Doesn't look like 2.3.1 will be released today, but I REALLY want to push these bugfixes out.) Removed bundled Rack (Rails 2.3.1 comes bundled with Rack 1.0). Add config.action_view.cache_template_loading = true to production environment. Fix FastCGI bug (http://rubyforge.org/tracker/index.php?func=detail&aid=24191&group_id=186&atid=783). Fix WikiWords bug (http://rubyforge.org/pipermail/instiki-users/2009-February/001181.html).
This commit is contained in:
parent
0ddef97328
commit
133c21b801
641 changed files with 20541 additions and 71675 deletions
|
@ -1,84 +0,0 @@
|
|||
require 'test/spec'
|
||||
|
||||
require 'rack/session/pool'
|
||||
require 'rack/mock'
|
||||
require 'rack/response'
|
||||
require 'thread'
|
||||
|
||||
context "Rack::Session::Pool" do
|
||||
incrementor = lambda { |env|
|
||||
env["rack.session"]["counter"] ||= 0
|
||||
env["rack.session"]["counter"] += 1
|
||||
Rack::Response.new(env["rack.session"].inspect).to_a
|
||||
}
|
||||
|
||||
specify "creates a new cookie" do
|
||||
pool = Rack::Session::Pool.new(incrementor)
|
||||
res = Rack::MockRequest.new(pool).get("/")
|
||||
res["Set-Cookie"].should.match("rack.session=")
|
||||
res.body.should.equal '{"counter"=>1}'
|
||||
end
|
||||
|
||||
specify "determines session from a cookie" do
|
||||
pool = Rack::Session::Pool.new(incrementor)
|
||||
res = Rack::MockRequest.new(pool).get("/")
|
||||
cookie = res["Set-Cookie"]
|
||||
res = Rack::MockRequest.new(pool).get("/", "HTTP_COOKIE" => cookie)
|
||||
res.body.should.equal '{"counter"=>2}'
|
||||
res = Rack::MockRequest.new(pool).get("/", "HTTP_COOKIE" => cookie)
|
||||
res.body.should.equal '{"counter"=>3}'
|
||||
end
|
||||
|
||||
specify "survives broken cookies" do
|
||||
pool = Rack::Session::Pool.new(incrementor)
|
||||
res = Rack::MockRequest.new(pool).
|
||||
get("/", "HTTP_COOKIE" => "rack.session=blarghfasel")
|
||||
res.body.should.equal '{"counter"=>1}'
|
||||
end
|
||||
|
||||
specify "maintains freshness" do
|
||||
pool = Rack::Session::Pool.new(incrementor, :expire_after => 3)
|
||||
res = Rack::MockRequest.new(pool).get('/')
|
||||
res.body.should.include '"counter"=>1'
|
||||
cookie = res["Set-Cookie"]
|
||||
res = Rack::MockRequest.new(pool).get('/', "HTTP_COOKIE" => cookie)
|
||||
res["Set-Cookie"].should.equal cookie
|
||||
res.body.should.include '"counter"=>2'
|
||||
sleep 4
|
||||
res = Rack::MockRequest.new(pool).get('/', "HTTP_COOKIE" => cookie)
|
||||
res["Set-Cookie"].should.not.equal cookie
|
||||
res.body.should.include '"counter"=>1'
|
||||
end
|
||||
|
||||
specify "multithread: should merge sessions" do
|
||||
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
|
||||
pool = Rack::Session::Pool.new(incrementor)
|
||||
res = Rack::MockRequest.new(pool).get('/')
|
||||
res.body.should.equal '{"counter"=>1}'
|
||||
cookie = res["Set-Cookie"]
|
||||
sess_id = cookie[/#{pool.key}=([^,;]+)/,1]
|
||||
|
||||
pool = pool.context(delta_incrementor)
|
||||
r = Array.new(rand(7).to_i+3).
|
||||
map! do
|
||||
Thread.new do
|
||||
Rack::MockRequest.new(pool).get('/', "HTTP_COOKIE" => cookie)
|
||||
end
|
||||
end.
|
||||
reverse!.
|
||||
map!{|t| t.run.join.value }
|
||||
session = pool.for.pool[sess_id] # for is needed by Utils::Context
|
||||
session.size.should.be r.size+1 # counter
|
||||
session['counter'].should.be 2 # meeeh
|
||||
r.each do |res|
|
||||
res['Set-Cookie'].should.equal cookie
|
||||
res.body.should.include '"counter"=>2'
|
||||
end
|
||||
end
|
||||
end
|
Loading…
Add table
Add a link
Reference in a new issue