2009-01-13 12:53:53 -05:00
|
|
|
require File.dirname(__FILE__) + '/helper'
|
2008-09-07 08:02:10 -04:00
|
|
|
|
2009-03-26 11:42:13 -04:00
|
|
|
class FilterTest < Test::Unit::TestCase
|
2008-12-13 16:06:02 -05:00
|
|
|
it "executes filters in the order defined" do
|
|
|
|
count = 0
|
|
|
|
mock_app do
|
|
|
|
get('/') { 'Hello World' }
|
|
|
|
before {
|
2009-01-15 07:04:10 -05:00
|
|
|
assert_equal 0, count
|
2008-12-13 16:06:02 -05:00
|
|
|
count = 1
|
|
|
|
}
|
|
|
|
before {
|
2009-01-15 07:04:10 -05:00
|
|
|
assert_equal 1, count
|
2008-12-13 16:06:02 -05:00
|
|
|
count = 2
|
|
|
|
}
|
|
|
|
end
|
2008-09-07 08:02:10 -04:00
|
|
|
|
2008-12-13 16:06:02 -05:00
|
|
|
get '/'
|
2009-01-14 17:00:26 -05:00
|
|
|
assert ok?
|
|
|
|
assert_equal 2, count
|
|
|
|
assert_equal 'Hello World', body
|
2008-09-07 08:02:10 -04:00
|
|
|
end
|
|
|
|
|
2008-12-13 16:06:02 -05:00
|
|
|
it "allows filters to modify the request" do
|
|
|
|
mock_app {
|
|
|
|
get('/foo') { 'foo' }
|
|
|
|
get('/bar') { 'bar' }
|
|
|
|
before { request.path_info = '/bar' }
|
|
|
|
}
|
|
|
|
|
|
|
|
get '/foo'
|
2009-01-14 17:00:26 -05:00
|
|
|
assert ok?
|
|
|
|
assert_equal 'bar', body
|
2008-09-07 08:02:10 -04:00
|
|
|
end
|
2009-01-18 07:00:55 -05:00
|
|
|
|
2009-01-18 08:37:36 -05:00
|
|
|
it "can modify instance variables available to routes" do
|
|
|
|
mock_app {
|
|
|
|
before { @foo = 'bar' }
|
|
|
|
get('/foo') { @foo }
|
|
|
|
}
|
|
|
|
|
|
|
|
get '/foo'
|
|
|
|
assert ok?
|
|
|
|
assert_equal 'bar', body
|
|
|
|
end
|
|
|
|
|
2009-01-18 07:00:55 -05:00
|
|
|
it "allows redirects in filters" do
|
|
|
|
mock_app {
|
|
|
|
before { redirect '/bar' }
|
2009-01-18 08:37:36 -05:00
|
|
|
get('/foo') do
|
|
|
|
fail 'before block should have halted processing'
|
|
|
|
'ORLY?!'
|
|
|
|
end
|
2009-01-18 07:00:55 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
get '/foo'
|
|
|
|
assert redirect?
|
|
|
|
assert_equal '/bar', response['Location']
|
2009-01-18 08:37:36 -05:00
|
|
|
assert_equal '', body
|
2009-01-18 07:00:55 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
it "does not modify the response with its return value" do
|
|
|
|
mock_app {
|
|
|
|
before { 'Hello World!' }
|
|
|
|
get '/foo' do
|
|
|
|
assert_equal [], response.body
|
|
|
|
'cool'
|
|
|
|
end
|
|
|
|
}
|
|
|
|
|
|
|
|
get '/foo'
|
|
|
|
assert ok?
|
|
|
|
assert_equal 'cool', body
|
|
|
|
end
|
2009-01-24 23:33:06 -05:00
|
|
|
|
2009-01-25 02:41:09 -05:00
|
|
|
it "does modify the response with halt" do
|
|
|
|
mock_app {
|
|
|
|
before { halt 302, 'Hi' }
|
|
|
|
get '/foo' do
|
|
|
|
"should not happen"
|
|
|
|
end
|
|
|
|
}
|
|
|
|
|
|
|
|
get '/foo'
|
|
|
|
assert_equal 302, response.status
|
|
|
|
assert_equal 'Hi', body
|
|
|
|
end
|
|
|
|
|
2009-01-24 23:33:06 -05:00
|
|
|
it "gives you access to params" do
|
|
|
|
mock_app {
|
|
|
|
before { @foo = params['foo'] }
|
|
|
|
get('/foo') { @foo }
|
|
|
|
}
|
|
|
|
|
|
|
|
get '/foo?foo=cool'
|
|
|
|
assert ok?
|
|
|
|
assert_equal 'cool', body
|
|
|
|
end
|
2008-09-07 08:02:10 -04:00
|
|
|
end
|