test/spec_recursive.rb in rack-1.6.13 vs test/spec_recursive.rb in rack-2.0.0.alpha
- old
+ new
@@ -1,10 +1,12 @@
+require 'minitest/autorun'
require 'rack/lint'
require 'rack/recursive'
require 'rack/mock'
describe Rack::Recursive do
+ before do
@app1 = lambda { |env|
res = Rack::Response.new
res["X-Path-Info"] = env["PATH_INFO"]
res["X-Query-String"] = env["QUERY_STRING"]
res.finish do |inner_res|
@@ -27,46 +29,47 @@
}
@app4 = lambda { |env|
raise Rack::ForwardRequest.new("http://example.org/app1/quux?meh")
}
-
+ end
+
def recursive(map)
Rack::Lint.new Rack::Recursive.new(Rack::URLMap.new(map))
end
- should "allow for subrequests" do
+ it "allow for subrequests" do
res = Rack::MockRequest.new(recursive("/app1" => @app1,
"/app2" => @app2)).
get("/app2")
- res.should.be.ok
- res.body.should.equal "App2App1"
+ res.must_be :ok?
+ res.body.must_equal "App2App1"
end
- should "raise error on requests not below the app" do
+ it "raise error on requests not below the app" do
app = Rack::URLMap.new("/app1" => @app1,
"/app" => recursive("/1" => @app1,
"/2" => @app2))
lambda {
Rack::MockRequest.new(app).get("/app/2")
- }.should.raise(ArgumentError).
- message.should =~ /can only include below/
+ }.must_raise(ArgumentError).
+ message.must_match(/can only include below/)
end
- should "support forwarding" do
+ it "support forwarding" do
app = recursive("/app1" => @app1,
"/app3" => @app3,
"/app4" => @app4)
res = Rack::MockRequest.new(app).get("/app3")
- res.should.be.ok
- res.body.should.equal "App1"
+ res.must_be :ok?
+ res.body.must_equal "App1"
res = Rack::MockRequest.new(app).get("/app4")
- res.should.be.ok
- res.body.should.equal "App1"
- res["X-Path-Info"].should.equal "/quux"
- res["X-Query-String"].should.equal "meh"
+ res.must_be :ok?
+ res.body.must_equal "App1"
+ res["X-Path-Info"].must_equal "/quux"
+ res["X-Query-String"].must_equal "meh"
end
end