mirror of
https://github.com/pry/pry.git
synced 2022-11-09 12:35:05 -05:00
278 lines
8.1 KiB
Ruby
278 lines
8.1 KiB
Ruby
require 'helper'
|
|
|
|
describe "Pry::Commands" do
|
|
|
|
after do
|
|
$obj = nil
|
|
end
|
|
|
|
describe "hist" do
|
|
push_first_hist_line = lambda do |hist, line|
|
|
hist.push line while hist.empty?
|
|
end
|
|
|
|
before do
|
|
Readline::HISTORY.shift until Readline::HISTORY.empty?
|
|
@hist = Readline::HISTORY
|
|
end
|
|
|
|
it 'should display the correct history' do
|
|
push_first_hist_line.call(@hist, "'bug in 1.8 means this line is ignored'")
|
|
@hist.push "hello"
|
|
@hist.push "world"
|
|
str_output = StringIO.new
|
|
redirect_pry_io(InputTester.new("hist", "exit-all"), str_output) do
|
|
pry
|
|
end
|
|
str_output.string.should =~ /hello\n.*world/
|
|
end
|
|
|
|
it 'should replay history correctly (single item)' do
|
|
push_first_hist_line.call(@hist, ":hello")
|
|
@hist.push ":blah"
|
|
@hist.push ":bucket"
|
|
@hist.push ":ostrich"
|
|
str_output = StringIO.new
|
|
redirect_pry_io(InputTester.new("hist --replay -1", "exit-all"), str_output) do
|
|
pry
|
|
end
|
|
str_output.string.should =~ /ostrich/
|
|
end
|
|
|
|
it 'should replay a range of history correctly (range of items)' do
|
|
push_first_hist_line.call(@hist, "'bug in 1.8 means this line is ignored'")
|
|
@hist.push ":hello"
|
|
@hist.push ":carl"
|
|
str_output = StringIO.new
|
|
redirect_pry_io(InputTester.new("hist --replay 0..2", "exit-all"), str_output) do
|
|
pry
|
|
end
|
|
str_output.string.should =~ /:hello\n.*:carl/
|
|
end
|
|
|
|
it 'should grep for correct lines in history' do
|
|
push_first_hist_line.call(@hist, "apple")
|
|
@hist.push "abby"
|
|
@hist.push "box"
|
|
@hist.push "button"
|
|
@hist.push "pepper"
|
|
@hist.push "orange"
|
|
@hist.push "grape"
|
|
|
|
str_output = StringIO.new
|
|
redirect_pry_io(InputTester.new("hist --grep o", "exit-all"), str_output) do
|
|
pry
|
|
end
|
|
|
|
str_output.string.should =~ /\d:.*?box\n\d:.*?button\n\d:.*?orange/
|
|
end
|
|
|
|
it 'should return last N lines in history with --tail switch' do
|
|
push_first_hist_line.call(@hist, "0")
|
|
("a".."z").each do |v|
|
|
@hist.push v
|
|
end
|
|
|
|
str_output = StringIO.new
|
|
redirect_pry_io(InputTester.new("hist --tail 3", "exit-all"), str_output) do
|
|
pry
|
|
end
|
|
|
|
str_output.string.each_line.count.should == 3
|
|
str_output.string.should =~ /x\n\d+:.*y\n\d+:.*z/
|
|
end
|
|
|
|
# strangeness in this test is due to bug in Readling::HISTORY not
|
|
# always registering first line of input
|
|
it 'should return first N lines in history with --head switch' do
|
|
push_first_hist_line.call(@hist, "0")
|
|
("a".."z").each do |v|
|
|
@hist.push v
|
|
end
|
|
|
|
str_output = StringIO.new
|
|
redirect_pry_io(InputTester.new("hist --head 4", "exit-all"), str_output) do
|
|
pry
|
|
end
|
|
|
|
str_output.string.each_line.count.should == 4
|
|
str_output.string.should =~ /a\n\d+:.*b\n\d+:.*c/
|
|
end
|
|
end
|
|
|
|
describe "show-method" do
|
|
it 'should output a method\'s source' do
|
|
str_output = StringIO.new
|
|
redirect_pry_io(InputTester.new("show-method sample_method", "exit-all"), str_output) do
|
|
pry
|
|
end
|
|
|
|
str_output.string.should =~ /def sample/
|
|
end
|
|
|
|
it 'should output a method\'s source with line numbers' do
|
|
str_output = StringIO.new
|
|
redirect_pry_io(InputTester.new("show-method -l sample_method", "exit-all"), str_output) do
|
|
pry
|
|
end
|
|
|
|
str_output.string.should =~ /\d+: def sample/
|
|
end
|
|
|
|
it 'should output a method\'s source if inside method without needing to use method name' do
|
|
$str_output = StringIO.new
|
|
|
|
o = Object.new
|
|
def o.sample
|
|
redirect_pry_io(InputTester.new("show-method", "exit-all"), $str_output) do
|
|
binding.pry
|
|
end
|
|
end
|
|
o.sample
|
|
|
|
$str_output.string.should =~ /def o.sample/
|
|
$str_output = nil
|
|
end
|
|
|
|
it 'should output a method\'s source if inside method without needing to use method name, and using the -l switch' do
|
|
$str_output = StringIO.new
|
|
|
|
o = Object.new
|
|
def o.sample
|
|
redirect_pry_io(InputTester.new("show-method -l", "exit-all"), $str_output) do
|
|
binding.pry
|
|
end
|
|
end
|
|
o.sample
|
|
|
|
$str_output.string.should =~ /\d+: def o.sample/
|
|
$str_output = nil
|
|
end
|
|
|
|
if RUBY_VERSION =~ /1.9/
|
|
it 'should output a method\'s source for a method defined inside pry' do
|
|
str_output = StringIO.new
|
|
redirect_pry_io(InputTester.new("def dyna_method", ":testing", "end", "show-method dyna_method"), str_output) do
|
|
TOPLEVEL_BINDING.pry
|
|
end
|
|
|
|
str_output.string.should =~ /def dyna_method/
|
|
Object.remove_method :dyna_method
|
|
end
|
|
|
|
it 'should output a method\'s source for a method defined inside pry, even if exceptions raised before hand' do
|
|
str_output = StringIO.new
|
|
redirect_pry_io(InputTester.new("bad code", "123", "bad code 2", "1 + 2", "def dyna_method", ":testing", "end", "show-method dyna_method"), str_output) do
|
|
TOPLEVEL_BINDING.pry
|
|
end
|
|
|
|
str_output.string.should =~ /def dyna_method/
|
|
Object.remove_method :dyna_method
|
|
end
|
|
|
|
it 'should output an instance method\'s source for a method defined inside pry' do
|
|
str_output = StringIO.new
|
|
redirect_pry_io(InputTester.new("class A", "def yo", "end", "end", "show-method A#yo"), str_output) do
|
|
TOPLEVEL_BINDING.pry
|
|
end
|
|
|
|
str_output.string.should =~ /def yo/
|
|
Object.remove_const :A
|
|
end
|
|
|
|
it 'should output an instance method\'s source for a method defined inside pry using define_method' do
|
|
str_output = StringIO.new
|
|
redirect_pry_io(InputTester.new("class A", "define_method(:yup) {}", "end", "end", "show-method A#yup"), str_output) do
|
|
TOPLEVEL_BINDING.pry
|
|
end
|
|
|
|
str_output.string.should =~ /define_method\(:yup\)/
|
|
Object.remove_const :A
|
|
end
|
|
end
|
|
end
|
|
|
|
describe "show-doc" do
|
|
it 'should output a method\'s documentation' do
|
|
str_output = StringIO.new
|
|
redirect_pry_io(InputTester.new("show-doc sample_method", "exit-all"), str_output) do
|
|
pry
|
|
end
|
|
|
|
str_output.string.should =~ /sample doc/
|
|
end
|
|
|
|
it 'should output a method\'s documentation if inside method without needing to use method name' do
|
|
$str_output = StringIO.new
|
|
|
|
o = Object.new
|
|
def o.sample
|
|
redirect_pry_io(InputTester.new("show-doc", "exit-all"), $str_output) do
|
|
binding.pry
|
|
end
|
|
end
|
|
o.sample
|
|
|
|
$str_output.string.should =~ /sample doc/
|
|
$str_output = nil
|
|
end
|
|
end
|
|
|
|
|
|
describe "cd" do
|
|
it 'should cd into simple input' do
|
|
b = Pry.binding_for(Object.new)
|
|
b.eval("x = :mon_ouie")
|
|
|
|
redirect_pry_io(InputTester.new("cd x", "$obj = self", "exit-all"), StringIO.new) do
|
|
b.pry
|
|
end
|
|
|
|
$obj.should == :mon_ouie
|
|
end
|
|
|
|
it 'should break out of session with cd ..' do
|
|
b = Pry.binding_for(:outer)
|
|
b.eval("x = :inner")
|
|
|
|
redirect_pry_io(InputTester.new("cd x", "$inner = self;", "cd ..", "$outer = self", "exit-all"), StringIO.new) do
|
|
b.pry
|
|
end
|
|
$inner.should == :inner
|
|
$outer.should == :outer
|
|
end
|
|
|
|
it 'should break out to outer-most session with cd /' do
|
|
b = Pry.binding_for(:outer)
|
|
b.eval("x = :inner")
|
|
|
|
redirect_pry_io(InputTester.new("cd x", "$inner = self;", "cd 5", "$five = self", "cd /", "$outer = self", "exit-all"), StringIO.new) do
|
|
b.pry
|
|
end
|
|
$inner.should == :inner
|
|
$five.should == 5
|
|
$outer.should == :outer
|
|
end
|
|
|
|
it 'should start a session on TOPLEVEL_BINDING with cd ::' do
|
|
b = Pry.binding_for(:outer)
|
|
|
|
redirect_pry_io(InputTester.new("cd ::", "$obj = self", "exit-all"), StringIO.new) do
|
|
5.pry
|
|
end
|
|
$obj.should == TOPLEVEL_BINDING.eval('self')
|
|
end
|
|
|
|
it 'should cd into complex input (with spaces)' do
|
|
o = Object.new
|
|
def o.hello(x, y, z)
|
|
:mon_ouie
|
|
end
|
|
|
|
redirect_pry_io(InputTester.new("cd hello 1, 2, 3", "$obj = self", "exit-all"), StringIO.new) do
|
|
o.pry
|
|
end
|
|
$obj.should == :mon_ouie
|
|
end
|
|
end
|
|
end
|