2009-12-18 20:16:58 -06:00
|
|
|
require 'rack/urlmap'
|
|
|
|
require 'rack/mock'
|
|
|
|
|
2010-06-13 23:09:24 -05:00
|
|
|
describe Rack::URLMap do
|
|
|
|
it "dispatches paths correctly" do
|
2009-12-18 20:16:58 -06:00
|
|
|
app = lambda { |env|
|
|
|
|
[200, {
|
|
|
|
'X-ScriptName' => env['SCRIPT_NAME'],
|
|
|
|
'X-PathInfo' => env['PATH_INFO'],
|
|
|
|
'Content-Type' => 'text/plain'
|
|
|
|
}, [""]]
|
|
|
|
}
|
|
|
|
map = Rack::URLMap.new({
|
|
|
|
'http://foo.org/bar' => app,
|
|
|
|
'/foo' => app,
|
|
|
|
'/foo/bar' => app
|
|
|
|
})
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/")
|
|
|
|
res.should.be.not_found
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/qux")
|
|
|
|
res.should.be.not_found
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/foo")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-ScriptName"].should.equal "/foo"
|
|
|
|
res["X-PathInfo"].should.equal ""
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/foo/")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-ScriptName"].should.equal "/foo"
|
|
|
|
res["X-PathInfo"].should.equal "/"
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/foo/bar")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-ScriptName"].should.equal "/foo/bar"
|
|
|
|
res["X-PathInfo"].should.equal ""
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/foo/bar/")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-ScriptName"].should.equal "/foo/bar"
|
|
|
|
res["X-PathInfo"].should.equal "/"
|
|
|
|
|
2009-12-26 14:00:18 -06:00
|
|
|
res = Rack::MockRequest.new(map).get("/foo///bar//quux")
|
|
|
|
res.status.should.equal 200
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-ScriptName"].should.equal "/foo/bar"
|
|
|
|
res["X-PathInfo"].should.equal "//quux"
|
|
|
|
|
2009-12-18 20:16:58 -06:00
|
|
|
res = Rack::MockRequest.new(map).get("/foo/quux", "SCRIPT_NAME" => "/bleh")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-ScriptName"].should.equal "/bleh/foo"
|
|
|
|
res["X-PathInfo"].should.equal "/quux"
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/bar", 'HTTP_HOST' => 'foo.org')
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-ScriptName"].should.equal "/bar"
|
|
|
|
res["X-PathInfo"].should.be.empty
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/bar/", 'HTTP_HOST' => 'foo.org')
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-ScriptName"].should.equal "/bar"
|
|
|
|
res["X-PathInfo"].should.equal '/'
|
|
|
|
end
|
|
|
|
|
|
|
|
|
2010-06-13 23:09:24 -05:00
|
|
|
it "dispatches hosts correctly" do
|
2009-12-18 20:16:58 -06:00
|
|
|
map = Rack::URLMap.new("http://foo.org/" => lambda { |env|
|
|
|
|
[200,
|
|
|
|
{ "Content-Type" => "text/plain",
|
|
|
|
"X-Position" => "foo.org",
|
|
|
|
"X-Host" => env["HTTP_HOST"] || env["SERVER_NAME"],
|
|
|
|
}, [""]]},
|
|
|
|
"http://subdomain.foo.org/" => lambda { |env|
|
|
|
|
[200,
|
|
|
|
{ "Content-Type" => "text/plain",
|
|
|
|
"X-Position" => "subdomain.foo.org",
|
|
|
|
"X-Host" => env["HTTP_HOST"] || env["SERVER_NAME"],
|
|
|
|
}, [""]]},
|
|
|
|
"http://bar.org/" => lambda { |env|
|
|
|
|
[200,
|
|
|
|
{ "Content-Type" => "text/plain",
|
|
|
|
"X-Position" => "bar.org",
|
|
|
|
"X-Host" => env["HTTP_HOST"] || env["SERVER_NAME"],
|
|
|
|
}, [""]]},
|
|
|
|
"/" => lambda { |env|
|
|
|
|
[200,
|
|
|
|
{ "Content-Type" => "text/plain",
|
|
|
|
"X-Position" => "default.org",
|
|
|
|
"X-Host" => env["HTTP_HOST"] || env["SERVER_NAME"],
|
|
|
|
}, [""]]}
|
|
|
|
)
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-Position"].should.equal "default.org"
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/", "HTTP_HOST" => "bar.org")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-Position"].should.equal "bar.org"
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/", "HTTP_HOST" => "foo.org")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-Position"].should.equal "foo.org"
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/", "HTTP_HOST" => "subdomain.foo.org", "SERVER_NAME" => "foo.org")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-Position"].should.equal "subdomain.foo.org"
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("http://foo.org/")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-Position"].should.equal "default.org"
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/", "HTTP_HOST" => "example.org")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-Position"].should.equal "default.org"
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/",
|
|
|
|
"HTTP_HOST" => "example.org:9292",
|
|
|
|
"SERVER_PORT" => "9292")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-Position"].should.equal "default.org"
|
|
|
|
end
|
|
|
|
|
2010-06-13 23:09:24 -05:00
|
|
|
should "be nestable" do
|
2009-12-18 20:16:58 -06:00
|
|
|
map = Rack::URLMap.new("/foo" =>
|
|
|
|
Rack::URLMap.new("/bar" =>
|
|
|
|
Rack::URLMap.new("/quux" => lambda { |env|
|
|
|
|
[200,
|
|
|
|
{ "Content-Type" => "text/plain",
|
|
|
|
"X-Position" => "/foo/bar/quux",
|
|
|
|
"X-PathInfo" => env["PATH_INFO"],
|
|
|
|
"X-ScriptName" => env["SCRIPT_NAME"],
|
|
|
|
}, [""]]}
|
|
|
|
)))
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/foo/bar")
|
|
|
|
res.should.be.not_found
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/foo/bar/quux")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-Position"].should.equal "/foo/bar/quux"
|
|
|
|
res["X-PathInfo"].should.equal ""
|
|
|
|
res["X-ScriptName"].should.equal "/foo/bar/quux"
|
|
|
|
end
|
|
|
|
|
2010-06-13 23:09:24 -05:00
|
|
|
should "route root apps correctly" do
|
2009-12-18 20:16:58 -06:00
|
|
|
map = Rack::URLMap.new("/" => lambda { |env|
|
|
|
|
[200,
|
|
|
|
{ "Content-Type" => "text/plain",
|
|
|
|
"X-Position" => "root",
|
|
|
|
"X-PathInfo" => env["PATH_INFO"],
|
|
|
|
"X-ScriptName" => env["SCRIPT_NAME"]
|
|
|
|
}, [""]]},
|
|
|
|
"/foo" => lambda { |env|
|
|
|
|
[200,
|
|
|
|
{ "Content-Type" => "text/plain",
|
|
|
|
"X-Position" => "foo",
|
|
|
|
"X-PathInfo" => env["PATH_INFO"],
|
|
|
|
"X-ScriptName" => env["SCRIPT_NAME"]
|
|
|
|
}, [""]]}
|
|
|
|
)
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/foo/bar")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-Position"].should.equal "foo"
|
|
|
|
res["X-PathInfo"].should.equal "/bar"
|
|
|
|
res["X-ScriptName"].should.equal "/foo"
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/foo")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-Position"].should.equal "foo"
|
|
|
|
res["X-PathInfo"].should.equal ""
|
|
|
|
res["X-ScriptName"].should.equal "/foo"
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/bar")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-Position"].should.equal "root"
|
|
|
|
res["X-PathInfo"].should.equal "/bar"
|
|
|
|
res["X-ScriptName"].should.equal ""
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-Position"].should.equal "root"
|
|
|
|
res["X-PathInfo"].should.equal "/"
|
|
|
|
res["X-ScriptName"].should.equal ""
|
|
|
|
end
|
2009-12-26 14:00:18 -06:00
|
|
|
|
2010-06-13 23:09:24 -05:00
|
|
|
should "not squeeze slashes" do
|
2009-12-26 14:00:18 -06:00
|
|
|
map = Rack::URLMap.new("/" => lambda { |env|
|
|
|
|
[200,
|
|
|
|
{ "Content-Type" => "text/plain",
|
|
|
|
"X-Position" => "root",
|
|
|
|
"X-PathInfo" => env["PATH_INFO"],
|
|
|
|
"X-ScriptName" => env["SCRIPT_NAME"]
|
|
|
|
}, [""]]},
|
|
|
|
"/foo" => lambda { |env|
|
|
|
|
[200,
|
|
|
|
{ "Content-Type" => "text/plain",
|
|
|
|
"X-Position" => "foo",
|
|
|
|
"X-PathInfo" => env["PATH_INFO"],
|
|
|
|
"X-ScriptName" => env["SCRIPT_NAME"]
|
|
|
|
}, [""]]}
|
|
|
|
)
|
|
|
|
|
|
|
|
res = Rack::MockRequest.new(map).get("/http://example.org/bar")
|
|
|
|
res.should.be.ok
|
|
|
|
res["X-Position"].should.equal "root"
|
|
|
|
res["X-PathInfo"].should.equal "/http://example.org/bar"
|
|
|
|
res["X-ScriptName"].should.equal ""
|
|
|
|
end
|
2009-12-18 20:16:58 -06:00
|
|
|
end
|