test/static_test.rb in adamwiggins-sinatra-0.8.9 vs test/static_test.rb in adamwiggins-sinatra-0.10.1
- old
+ new
@@ -1,60 +1,87 @@
-require 'test/spec'
-require 'sinatra/base'
-require 'sinatra/test'
+require File.dirname(__FILE__) + '/helper'
-describe 'Static' do
- include Sinatra::Test
- F = ::File
-
- before do
- @app = mock_app {
+class StaticTest < Test::Unit::TestCase
+ setup do
+ mock_app {
set :static, true
- set :public, F.dirname(__FILE__)
+ set :public, File.dirname(__FILE__)
}
end
it 'serves GET requests for files in the public directory' do
- get "/#{F.basename(__FILE__)}"
- should.be.ok
- body.should.equal File.read(__FILE__)
- response['Content-Length'].should.equal File.size(__FILE__).to_s
- response.headers.should.include 'Last-Modified'
+ get "/#{File.basename(__FILE__)}"
+ assert ok?
+ assert_equal File.read(__FILE__), body
+ assert_equal File.size(__FILE__).to_s, response['Content-Length']
+ assert response.headers.include?('Last-Modified')
end
+ it 'produces a body that can be iterated over multiple times' do
+ env = Rack::MockRequest.env_for("/#{File.basename(__FILE__)}")
+ status, headers, body = @app.call(env)
+ buf1, buf2 = [], []
+ body.each { |part| buf1 << part }
+ body.each { |part| buf2 << part }
+ assert_equal buf1.join, buf2.join
+ assert_equal File.read(__FILE__), buf1.join
+ end
+
it 'serves HEAD requests for files in the public directory' do
- head "/#{F.basename(__FILE__)}"
- should.be.ok
- body.should.be.empty
- response['Content-Length'].should.equal File.size(__FILE__).to_s
- response.headers.should.include 'Last-Modified'
+ head "/#{File.basename(__FILE__)}"
+ assert ok?
+ assert_equal '', body
+ assert_equal File.size(__FILE__).to_s, response['Content-Length']
+ assert response.headers.include?('Last-Modified')
end
+ %w[POST PUT DELETE].each do |verb|
+ it "does not serve #{verb} requests" do
+ send verb.downcase, "/#{File.basename(__FILE__)}"
+ assert_equal 404, status
+ end
+ end
+
it 'serves files in preference to custom routes' do
- @app.get("/#{F.basename(__FILE__)}") { 'Hello World' }
- get "/#{F.basename(__FILE__)}"
- should.be.ok
- body.should.not.equal 'Hello World'
+ @app.get("/#{File.basename(__FILE__)}") { 'Hello World' }
+ get "/#{File.basename(__FILE__)}"
+ assert ok?
+ assert body != 'Hello World'
end
it 'does not serve directories' do
get "/"
- should.be.not_found
+ assert not_found?
end
it 'passes to the next handler when the static option is disabled' do
@app.set :static, false
- get "/#{F.basename(__FILE__)}"
- should.be.not_found
+ get "/#{File.basename(__FILE__)}"
+ assert not_found?
end
it 'passes to the next handler when the public option is nil' do
@app.set :public, nil
- get "/#{F.basename(__FILE__)}"
- should.be.not_found
+ get "/#{File.basename(__FILE__)}"
+ assert not_found?
end
it '404s when a file is not found' do
get "/foobarbaz.txt"
- should.be.not_found
+ assert not_found?
+ end
+
+ it 'serves files when .. path traverses within public directory' do
+ get "/data/../#{File.basename(__FILE__)}"
+ assert ok?
+ assert_equal File.read(__FILE__), body
+ end
+
+ it '404s when .. path traverses outside of public directory' do
+ mock_app {
+ set :static, true
+ set :public, File.dirname(__FILE__) + '/data'
+ }
+ get "/../#{File.basename(__FILE__)}"
+ assert not_found?
end
end