require 'spec_helper' describe App do let (:app) { mock_app {} } it 'should return a rack response on call' do response = app.get '/' response.should be_a(Rack::Response) end it 'should return 404 for non-matched routes' do response = app.get random_url response.status.should == 404 end it 'should able to register a extension' do module Foo def foo end end kls = mock_app_class {} kls.register(Foo) kls.should respond_to(:foo) end describe 'namespace' do let (:app) do mock_app do namespace '/foo' do get '/' do 'bar' end end namespace '/nested' do namespace '/space' do get '/' do 'caramba' end end end get '/' do 'no namespace here' end end end it 'allows to specify stuff in namespaces' do app.get('/foo').body.should == 'bar' end it 'does not break the main app' do app.get('/').body.should == 'no namespace here' end it 'can be nested as well' do app.get('/nested/space/').body.should == 'caramba' end end it 'should call registered method on extension' do module Foo def self.registered app # end end class SomeApp < NYNY::App end Foo.should_receive(:registered).with(SomeApp) SomeApp.register(Foo) end it 'should match a route for any supported verbs' do url = random_url verb = App::HTTP_VERBS.sample app = mock_app do send verb, url do 'foo' end end res = app.send verb, url res.body.should == 'foo' end it 'should support route patterns' do app = mock_app do get '/some/:name' do 'foo' end get '/:name' do "hello #{params[:name]}" end end res = app.get '/foo' res.body.should == "hello foo" end it 'should support adding before filers' do app = mock_app do before do request.should_not == nil end get '/' do "hello" end end app.get('/') end it 'does not maintain state between requests' do app = mock_app do get '/state' do @foo ||= "new" body = "Foo: #{@foo}" @foo = 'discard' body end end 2.times do response = app.get('/state') response.should be_ok 'Foo: new'.should == response.body end end it 'acts well as a middleware' do app = lambda do |env| [210, {}, ['Hello from downstream']] end app_class = mock_app_class do get '/' do 'hello' end end frankie = app_class.new(app) req = Rack::MockRequest.new frankie res = req.get '/' res.body.should == 'hello' res2 = req.get '/ither' res2.body.should == 'Hello from downstream' end it 'should support adding after filers' do app = mock_app do after do response.should_not == nil end get '/' do "hello" end end app.get '/' end it 'works with empty path' do kls = mock_app_class do get '/' do 'Hello' end end env = Rack::MockRequest.env_for '/' env['PATH_INFO'] = '' kls.new.call(env)[2].body.last.should == 'Hello' end describe 'Class level api' do let (:app_class) { Class.new(App) } describe 'middlewares' do it 'delegates to builder' do kls = mock_app_class kls.builder.should_receive(:use).with(NullMiddleware) kls.use(NullMiddleware) end end describe 'helpers' do it 'should allow to include a helper in request scope' do app_class.helpers NullHelper app_class.scope_class.ancestors.should include(NullHelper) end it 'should allow to include multiple helpers modules' do module NullHelper2 end app_class.helpers NullHelper, NullHelper2 app_class.scope_class.ancestors.should include(NullHelper, NullHelper2) end it 'should allow to define helpers with a block' do app_class.helpers do def foo 'bar' end end app_class.get '/' do foo.should == 'bar' end req = Rack::MockRequest.env_for '/' res = app_class.new.call(req) end end end end