提交 e6dffb70 编写于 作者: J José Valim

reload! on console now works as expected. [#3822 status:resolved]

上级 bd36418c
......@@ -26,7 +26,7 @@ def new_session
# reloads the environment
def reload!(print=true)
puts "Reloading..." if print
ActionDispatch::Callbacks.new(lambda {}, false)
ActionDispatch::Callbacks.new(lambda {}, false).call({})
true
end
......
......@@ -6,7 +6,9 @@ class ConsoleTest < Test::Unit::TestCase
def setup
build_app
boot_rails
end
def load_environment
# Load steps taken from rails/commands/console.rb
require "#{rails_root}/config/environment"
require 'rails/console/app'
......@@ -14,18 +16,21 @@ def setup
end
def test_app_method_should_return_integration_session
load_environment
console_session = app
assert_not_nil console_session
assert_instance_of ActionController::Integration::Session, console_session
end
def test_new_session_should_return_integration_session
load_environment
session = new_session
assert_not_nil session
assert_instance_of ActionController::Integration::Session, session
end
def test_reload_should_fire_preparation_callbacks
load_environment
a = b = c = nil
# TODO: These should be defined on the initializer
......@@ -34,16 +39,37 @@ def test_reload_should_fire_preparation_callbacks
ActionDispatch::Callbacks.to_prepare { c = 3 }
# Hide Reloading... output
silence_stream(STDOUT) do
reload!
end
silence_stream(STDOUT) { reload! }
assert_equal 1, a
assert_equal 2, b
assert_equal 3, c
end
def test_reload_should_reload_constants
app_file "app/models/user.rb", <<-MODEL
class User
attr_accessor :name
end
MODEL
load_environment
assert User.new.respond_to?(:name)
assert !User.new.respond_to?(:age)
app_file "app/models/user.rb", <<-MODEL
class User
attr_accessor :name, :age
end
MODEL
assert !User.new.respond_to?(:age)
silence_stream(STDOUT) { reload! }
assert User.new.respond_to?(:age)
end
def test_access_to_helpers
load_environment
assert_not_nil helper
assert_instance_of ActionView::Base, helper
assert_equal 'Once upon a time in a world...',
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册