test/spec_file.rb in rack-1.4.1 vs test/spec_file.rb in rack-1.4.2
- old
+ new
@@ -1,56 +1,58 @@
require 'rack/file'
+require 'rack/lint'
require 'rack/mock'
describe Rack::File do
DOCROOT = File.expand_path(File.dirname(__FILE__)) unless defined? DOCROOT
+ def file(*args)
+ Rack::Lint.new Rack::File.new(*args)
+ end
+
should "serve files" do
- res = Rack::MockRequest.new(Rack::Lint.new(Rack::File.new(DOCROOT))).
- get("/cgi/test")
+ res = Rack::MockRequest.new(file(DOCROOT)).get("/cgi/test")
res.should.be.ok
res.should =~ /ruby/
end
should "set Last-Modified header" do
- res = Rack::MockRequest.new(Rack::Lint.new(Rack::File.new(DOCROOT))).
- get("/cgi/test")
+ res = Rack::MockRequest.new(file(DOCROOT)).get("/cgi/test")
path = File.join(DOCROOT, "/cgi/test")
res.should.be.ok
res["Last-Modified"].should.equal File.mtime(path).httpdate
end
should "return 304 if file isn't modified since last serve" do
path = File.join(DOCROOT, "/cgi/test")
- res = Rack::MockRequest.new(Rack::Lint.new(Rack::File.new(DOCROOT))).
+ res = Rack::MockRequest.new(file(DOCROOT)).
get("/cgi/test", 'HTTP_IF_MODIFIED_SINCE' => File.mtime(path).httpdate)
res.status.should.equal 304
res.body.should.be.empty
end
should "return the file if it's modified since last serve" do
path = File.join(DOCROOT, "/cgi/test")
- res = Rack::MockRequest.new(Rack::Lint.new(Rack::File.new(DOCROOT))).
+ res = Rack::MockRequest.new(file(DOCROOT)).
get("/cgi/test", 'HTTP_IF_MODIFIED_SINCE' => (File.mtime(path) - 100).httpdate)
res.should.be.ok
end
should "serve files with URL encoded filenames" do
- res = Rack::MockRequest.new(Rack::Lint.new(Rack::File.new(DOCROOT))).
- get("/cgi/%74%65%73%74") # "/cgi/test"
+ res = Rack::MockRequest.new(file(DOCROOT)).get("/cgi/%74%65%73%74") # "/cgi/test"
res.should.be.ok
res.should =~ /ruby/
end
should "allow safe directory traversal" do
- req = Rack::MockRequest.new(Rack::Lint.new(Rack::File.new(DOCROOT)))
+ req = Rack::MockRequest.new(file(DOCROOT))
res = req.get('/cgi/../cgi/test')
res.should.be.successful
res = req.get('.')
@@ -59,11 +61,11 @@
res = req.get("test/..")
res.should.be.not_found
end
should "not allow unsafe directory traversal" do
- req = Rack::MockRequest.new(Rack::Lint.new(Rack::File.new(DOCROOT)))
+ req = Rack::MockRequest.new(file(DOCROOT))
res = req.get("/../README")
res.should.be.client_error
res = req.get("../test")
@@ -74,11 +76,11 @@
res.should.be.not_found
end
should "allow files with .. in their name" do
- req = Rack::MockRequest.new(Rack::Lint.new(Rack::File.new(DOCROOT)))
+ req = Rack::MockRequest.new(file(DOCROOT))
res = req.get("/cgi/..test")
res.should.be.not_found
res = req.get("/cgi/test..")
res.should.be.not_found
@@ -86,34 +88,30 @@
res = req.get("/cgi../test..")
res.should.be.not_found
end
should "not allow unsafe directory traversal with encoded periods" do
- res = Rack::MockRequest.new(Rack::Lint.new(Rack::File.new(DOCROOT))).
- get("/%2E%2E/README")
+ res = Rack::MockRequest.new(file(DOCROOT)).get("/%2E%2E/README")
res.should.be.client_error?
res.should.be.not_found
end
should "allow safe directory traversal with encoded periods" do
- res = Rack::MockRequest.new(Rack::Lint.new(Rack::File.new(DOCROOT))).
- get("/cgi/%2E%2E/cgi/test")
+ res = Rack::MockRequest.new(file(DOCROOT)).get("/cgi/%2E%2E/cgi/test")
res.should.be.successful
end
should "404 if it can't find the file" do
- res = Rack::MockRequest.new(Rack::Lint.new(Rack::File.new(DOCROOT))).
- get("/cgi/blubb")
+ res = Rack::MockRequest.new(file(DOCROOT)).get("/cgi/blubb")
res.should.be.not_found
end
should "detect SystemCallErrors" do
- res = Rack::MockRequest.new(Rack::Lint.new(Rack::File.new(DOCROOT))).
- get("/cgi")
+ res = Rack::MockRequest.new(file(DOCROOT)).get("/cgi")
res.should.be.not_found
end
should "return bodies that respond to #to_path" do
@@ -128,38 +126,57 @@
end
should "return correct byte range in body" do
env = Rack::MockRequest.env_for("/cgi/test")
env["HTTP_RANGE"] = "bytes=22-33"
- res = Rack::MockResponse.new(*Rack::File.new(DOCROOT).call(env))
+ res = Rack::MockResponse.new(*file(DOCROOT).call(env))
res.status.should.equal 206
res["Content-Length"].should.equal "12"
res["Content-Range"].should.equal "bytes 22-33/193"
res.body.should.equal "-*- ruby -*-"
end
should "return error for unsatisfiable byte range" do
env = Rack::MockRequest.env_for("/cgi/test")
env["HTTP_RANGE"] = "bytes=1234-5678"
- res = Rack::MockResponse.new(*Rack::File.new(DOCROOT).call(env))
+ res = Rack::MockResponse.new(*file(DOCROOT).call(env))
res.status.should.equal 416
res["Content-Range"].should.equal "bytes */193"
end
- should "support cache control options" do
+ should "support legacy cache control options provided as string" do
env = Rack::MockRequest.env_for("/cgi/test")
- status, heads, _ = Rack::File.new(DOCROOT, 'public, max-age=38').call(env)
+ status, heads, _ = file(DOCROOT, 'public, max-age=38').call(env)
status.should.equal 200
heads['Cache-Control'].should.equal 'public, max-age=38'
end
+ should "support custom http headers" do
+ env = Rack::MockRequest.env_for("/cgi/test")
+ status, heads, _ = file(DOCROOT, 'Cache-Control' => 'public, max-age=38',
+ 'Access-Control-Allow-Origin' => '*').call(env)
+
+ status.should.equal 200
+ heads['Cache-Control'].should.equal 'public, max-age=38'
+ heads['Access-Control-Allow-Origin'].should.equal '*'
+ end
+
+ should "support not add custom http headers if none are supplied" do
+ env = Rack::MockRequest.env_for("/cgi/test")
+ status, heads, _ = file(DOCROOT).call(env)
+
+ status.should.equal 200
+ heads['Cache-Control'].should.equal nil
+ heads['Access-Control-Allow-Origin'].should.equal nil
+ end
+
should "only support GET and HEAD requests" do
- req = Rack::MockRequest.new(Rack::Lint.new(Rack::File.new(DOCROOT)))
+ req = Rack::MockRequest.new(file(DOCROOT))
- forbidden = %w[post put delete]
+ forbidden = %w[post put patch delete]
forbidden.each do |method|
res = req.send(method, "/cgi/test")
res.should.be.client_error
res.should.be.method_not_allowed