require File.expand_path(File.dirname(__FILE__) + '/helper') require 'haml' class PadrinoPristine < Padrino::Application; end class PadrinoTestApp < Padrino::Application; end class PadrinoTestApp2 < Padrino::Application; end describe "Application" do before { Padrino.clear! } after { remove_views } context 'for application functionality' do should 'check default options' do assert File.identical?(__FILE__, PadrinoPristine.app_file) assert_equal :padrino_pristine, PadrinoPristine.app_name assert_equal :test, PadrinoPristine.environment assert_equal Padrino.root('views'), PadrinoPristine.views assert PadrinoPristine.raise_errors assert !PadrinoPristine.logging assert !PadrinoPristine.sessions assert !PadrinoPristine.dump_errors assert !PadrinoPristine.show_exceptions assert PadrinoPristine.raise_errors assert !Padrino.configure_apps end should 'check padrino specific options' do assert !PadrinoPristine.instance_variable_get(:@_configured) PadrinoPristine.send(:setup_application!) assert_equal :padrino_pristine, PadrinoPristine.app_name assert_equal 'StandardFormBuilder', PadrinoPristine.default_builder assert PadrinoPristine.instance_variable_get(:@_configured) assert !PadrinoPristine.reload? end should 'set global project settings' do Padrino.configure_apps { enable :sessions; set :foo, "bar" } PadrinoTestApp.send(:default_configuration!) PadrinoTestApp2.send(:default_configuration!) assert PadrinoTestApp.sessions, "should have sessions enabled" assert_equal "bar", PadrinoTestApp.settings.foo, "should have foo assigned" assert_equal PadrinoTestApp.session_secret, PadrinoTestApp2.session_secret end should 'be able to configure_apps multiple times' do Padrino.configure_apps { set :foo1, "bar" } Padrino.configure_apps { set :foo1, "bam" } Padrino.configure_apps { set :foo2, "baz" } PadrinoTestApp.send(:default_configuration!) assert_equal "bam", PadrinoTestApp.settings.foo1, "should have foo1 assigned to bam" assert_equal "baz", PadrinoTestApp.settings.foo2, "should have foo2 assigned to baz" end should "have shared sessions accessible in project" do Padrino.configure_apps { enable :sessions; set :session_secret, 'secret' } Padrino.mount("PadrinoTestApp").to("/write") Padrino.mount("PadrinoTestApp2").to("/read") PadrinoTestApp.send :default_configuration! PadrinoTestApp.get('/') { session[:foo] = "shared" } PadrinoTestApp2.send(:default_configuration!) PadrinoTestApp2.get('/') { session[:foo] } @app = Padrino.application get '/write' get '/read' assert_equal 'shared', body end # compare to: test_routing: allow global provides should "set content_type to nil if none can be determined" do mock_app do provides :xml get("/foo"){ "Foo in #{content_type.inspect}" } get("/bar"){ "Foo in #{content_type.inspect}" } end get '/foo', {}, { 'HTTP_ACCEPT' => 'application/xml' } assert_equal 'Foo in :xml', body get '/foo' assert_equal 'Foo in :xml', body get '/bar', {}, { 'HTTP_ACCEPT' => 'application/xml' } assert_equal "Foo in nil", body end should "resolve views and layouts paths" do assert_equal Padrino.root('views')+'/users/index', PadrinoPristine.view_path('users/index') assert_equal Padrino.root('views')+'/layouts/app', PadrinoPristine.layout_path(:app) end context "errors" do should "haven't mapped errors on development" do mock_app { get('/'){ 'HI' } } get "/" assert @app.errors.empty? end should "have mapped errors on production" do mock_app { set :environment, :production; get('/'){ 'HI' } } get "/" assert_equal 1, @app.errors.size end should "overide errors" do mock_app do set :environment, :production get('/'){ raise } error(::Exception){ 'custom error' } end get "/" assert_equal 1, @app.errors.size assert_equal 'custom error', body end end end # application functionality end