1
0
Fork 0
mirror of https://github.com/pry/pry.git synced 2022-11-09 12:35:05 -05:00
pry--pry/test/test_default_commands/test_find_method.rb
2012-07-18 23:30:16 -07:00

63 lines
1.9 KiB
Ruby

require 'helper'
# we turn off the test for MRI 1.8 because our source_location hack
# for C methods actually runs the methods - and since it runs ALL
# methods (in an attempt to find a match) it runs 'exit' and aborts
# the test, causing a failure. We should fix this in the future by
# blacklisting certain methods for 1.8 MRI (such as exit, fork, and so on)
unless Pry::Helpers::BaseHelpers.mri_18?
MyKlass = Class.new do
def hello
"timothy"
end
def goodbye
"jenny"
end
def tea_tim?
"timothy"
end
def tea_time?
"polly"
end
end
describe "find-method" do
describe "find matching methods by name regex (-n option)" do
it "should find a method by regex" do
mock_pry("find-method hell MyKlass").should =~ /MyKlass.*?hello/m
end
it "should NOT match a method that does not match the regex" do
mock_pry("find-method hell MyKlass").should.not =~ /MyKlass.*?goodbye/m
end
end
describe "find matching methods by content regex (-c option)" do
it "should find a method by regex" do
mock_pry("find-method -c timothy MyKlass").should =~ /MyKlass.*?hello/m
end
it "should NOT match a method that does not match the regex" do
mock_pry("find-method timothy MyKlass").should.not =~ /MyKlass.*?goodbye/m
end
end
it "should work with badly behaved constants" do
MyKlass::X = Object.new
def (MyKlass::X).hash
raise "mooo"
end
mock_pry("find-method -c timothy MyKlass").should =~ /MyKlass.*?hello/m
end
it "should escape regexes correctly" do
mock_pry('find-method tea_time? MyKlass').should =~ /tea_tim\?/
mock_pry('find-method tea_time? MyKlass').should =~ /tea_time\?/
mock_pry('find-method tea_time\? MyKlass').should.not =~ /tea_tim\?/
mock_pry('find-method tea_time\? MyKlass').should =~ /tea_time\?/
end
end
Object.remove_const(:MyKlass)
end