2009-10-05 10:41:08 -04:00
|
|
|
require 'isolation/abstract_unit'
|
|
|
|
|
2012-01-05 20:30:17 -05:00
|
|
|
class ConsoleTest < ActiveSupport::TestCase
|
2011-06-06 08:54:05 -04:00
|
|
|
include ActiveSupport::Testing::Isolation
|
2009-10-05 10:41:08 -04:00
|
|
|
|
|
|
|
def setup
|
|
|
|
build_app
|
|
|
|
boot_rails
|
2010-02-26 06:09:39 -05:00
|
|
|
end
|
2009-10-05 10:41:08 -04:00
|
|
|
|
2011-06-06 06:43:22 -04:00
|
|
|
def teardown
|
2011-06-06 08:54:05 -04:00
|
|
|
teardown_app
|
2011-06-06 06:43:22 -04:00
|
|
|
end
|
|
|
|
|
2011-05-04 10:39:01 -04:00
|
|
|
def load_environment(sandbox = false)
|
2009-10-05 10:41:08 -04:00
|
|
|
require "#{rails_root}/config/environment"
|
2011-05-24 19:37:55 -04:00
|
|
|
Rails.application.sandbox = sandbox
|
|
|
|
Rails.application.load_console
|
2009-10-05 10:41:08 -04:00
|
|
|
end
|
|
|
|
|
2011-11-03 15:50:53 -04:00
|
|
|
def irb_context
|
2011-11-09 01:42:19 -05:00
|
|
|
Object.new.extend(Rails::ConsoleMethods)
|
2011-11-03 15:50:53 -04:00
|
|
|
end
|
|
|
|
|
2009-10-05 10:41:08 -04:00
|
|
|
def test_app_method_should_return_integration_session
|
2010-10-06 11:18:59 -04:00
|
|
|
TestHelpers::Rack.send :remove_method, :app
|
2010-02-26 06:09:39 -05:00
|
|
|
load_environment
|
2011-11-03 15:50:53 -04:00
|
|
|
console_session = irb_context.app
|
2010-09-24 20:15:52 -04:00
|
|
|
assert_instance_of ActionDispatch::Integration::Session, console_session
|
2009-10-05 10:41:08 -04:00
|
|
|
end
|
|
|
|
|
2015-06-05 03:30:54 -04:00
|
|
|
def test_app_can_access_path_helper_method
|
|
|
|
app_file 'config/routes.rb', <<-RUBY
|
|
|
|
Rails.application.routes.draw do
|
|
|
|
get 'foo', to: 'foo#index'
|
|
|
|
end
|
|
|
|
RUBY
|
|
|
|
|
|
|
|
load_environment
|
|
|
|
console_session = irb_context.app
|
|
|
|
assert_equal '/foo', console_session.foo_path
|
|
|
|
end
|
|
|
|
|
2009-10-05 10:41:08 -04:00
|
|
|
def test_new_session_should_return_integration_session
|
2010-02-26 06:09:39 -05:00
|
|
|
load_environment
|
2011-11-03 15:50:53 -04:00
|
|
|
session = irb_context.new_session
|
2010-09-24 20:15:52 -04:00
|
|
|
assert_instance_of ActionDispatch::Integration::Session, session
|
2009-10-05 10:41:08 -04:00
|
|
|
end
|
|
|
|
|
2010-12-19 18:58:58 -05:00
|
|
|
def test_reload_should_fire_preparation_and_cleanup_callbacks
|
2010-02-26 06:09:39 -05:00
|
|
|
load_environment
|
2009-10-05 10:41:08 -04:00
|
|
|
a = b = c = nil
|
|
|
|
|
|
|
|
# TODO: These should be defined on the initializer
|
2010-12-20 06:41:49 -05:00
|
|
|
ActionDispatch::Reloader.to_cleanup { a = b = c = 1 }
|
|
|
|
ActionDispatch::Reloader.to_cleanup { b = c = 2 }
|
|
|
|
ActionDispatch::Reloader.to_prepare { c = 3 }
|
2009-10-05 10:41:08 -04:00
|
|
|
|
|
|
|
# Hide Reloading... output
|
2011-11-03 15:50:53 -04:00
|
|
|
silence_stream(STDOUT) { irb_context.reload! }
|
2009-10-05 10:41:08 -04:00
|
|
|
|
|
|
|
assert_equal 1, a
|
|
|
|
assert_equal 2, b
|
|
|
|
assert_equal 3, c
|
|
|
|
end
|
|
|
|
|
2010-02-26 06:09:39 -05:00
|
|
|
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)
|
2011-12-12 16:51:33 -05:00
|
|
|
|
2010-02-26 06:09:39 -05:00
|
|
|
app_file "app/models/user.rb", <<-MODEL
|
|
|
|
class User
|
|
|
|
attr_accessor :name, :age
|
|
|
|
end
|
|
|
|
MODEL
|
|
|
|
|
|
|
|
assert !User.new.respond_to?(:age)
|
2011-11-03 15:50:53 -04:00
|
|
|
silence_stream(STDOUT) { irb_context.reload! }
|
2010-02-26 06:09:39 -05:00
|
|
|
assert User.new.respond_to?(:age)
|
|
|
|
end
|
|
|
|
|
2009-10-05 10:41:08 -04:00
|
|
|
def test_access_to_helpers
|
2010-02-26 06:09:39 -05:00
|
|
|
load_environment
|
2011-11-03 15:50:53 -04:00
|
|
|
helper = irb_context.helper
|
2009-10-05 10:41:08 -04:00
|
|
|
assert_not_nil helper
|
|
|
|
assert_instance_of ActionView::Base, helper
|
|
|
|
assert_equal 'Once upon a time in a world...',
|
|
|
|
helper.truncate('Once upon a time in a world far far away')
|
|
|
|
end
|
2013-03-08 08:34:58 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
begin
|
|
|
|
require "pty"
|
|
|
|
rescue LoadError
|
|
|
|
end
|
2010-07-17 04:59:41 -04:00
|
|
|
|
2013-03-08 08:34:58 -05:00
|
|
|
class FullStackConsoleTest < ActiveSupport::TestCase
|
|
|
|
def setup
|
|
|
|
skip "PTY unavailable" unless defined?(PTY) && PTY.respond_to?(:open)
|
2011-05-04 10:39:01 -04:00
|
|
|
|
2013-03-08 08:34:58 -05:00
|
|
|
build_app
|
|
|
|
app_file 'app/models/post.rb', <<-CODE
|
|
|
|
class Post < ActiveRecord::Base
|
|
|
|
end
|
|
|
|
CODE
|
|
|
|
system "#{app_path}/bin/rails runner 'Post.connection.create_table :posts'"
|
|
|
|
|
|
|
|
@master, @slave = PTY.open
|
|
|
|
end
|
|
|
|
|
|
|
|
def teardown
|
|
|
|
teardown_app
|
|
|
|
end
|
|
|
|
|
2013-03-09 15:32:01 -05:00
|
|
|
def assert_output(expected, timeout = 1)
|
2013-03-08 08:34:58 -05:00
|
|
|
timeout = Time.now + timeout
|
|
|
|
|
|
|
|
output = ""
|
|
|
|
until output.include?(expected) || Time.now > timeout
|
|
|
|
if IO.select([@master], [], [], 0.1)
|
2013-03-09 15:32:01 -05:00
|
|
|
output << @master.read(1)
|
2011-05-04 10:39:01 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-03-08 08:34:58 -05:00
|
|
|
assert output.include?(expected), "#{expected.inspect} expected, but got:\n\n#{output}"
|
|
|
|
end
|
|
|
|
|
2013-03-08 10:10:00 -05:00
|
|
|
def write_prompt(command, expected_output = nil)
|
2013-03-08 08:34:58 -05:00
|
|
|
@master.puts command
|
|
|
|
assert_output command
|
2013-03-08 10:10:00 -05:00
|
|
|
assert_output expected_output if expected_output
|
|
|
|
assert_output "> "
|
2013-03-08 08:34:58 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def spawn_console
|
2013-03-31 11:20:21 -04:00
|
|
|
Process.spawn(
|
2013-03-08 08:34:58 -05:00
|
|
|
"#{app_path}/bin/rails console --sandbox",
|
|
|
|
in: @slave, out: @slave, err: @slave
|
|
|
|
)
|
|
|
|
|
2013-03-09 12:48:48 -05:00
|
|
|
assert_output "> ", 30
|
2013-03-08 08:34:58 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_sandbox
|
2013-03-31 11:20:21 -04:00
|
|
|
spawn_console
|
2013-03-08 08:34:58 -05:00
|
|
|
|
2013-03-08 10:10:00 -05:00
|
|
|
write_prompt "Post.count", "=> 0"
|
2013-03-08 08:34:58 -05:00
|
|
|
write_prompt "Post.create"
|
2013-03-08 10:10:00 -05:00
|
|
|
write_prompt "Post.count", "=> 1"
|
2013-03-22 10:24:36 -04:00
|
|
|
@master.puts "quit"
|
2013-03-08 08:34:58 -05:00
|
|
|
|
2013-03-31 11:20:21 -04:00
|
|
|
spawn_console
|
2013-03-08 08:34:58 -05:00
|
|
|
|
2013-03-08 10:10:00 -05:00
|
|
|
write_prompt "Post.count", "=> 0"
|
|
|
|
write_prompt "Post.transaction { Post.create; raise }"
|
|
|
|
write_prompt "Post.count", "=> 0"
|
2013-03-22 10:24:36 -04:00
|
|
|
@master.puts "quit"
|
2011-05-04 10:39:01 -04:00
|
|
|
end
|
2009-10-05 10:41:08 -04:00
|
|
|
end
|