1
0
Fork 0
mirror of https://github.com/pry/pry.git synced 2022-11-09 12:35:05 -05:00
pry--pry/spec/commands/find_method_spec.rb
Kyrylo Silin 18c45d26c5 rubocop: enable the Style/FrozenStringLiteralComment cop
This will greatly ease Pry support on Ruby 3.0 (when it's out).
2019-05-08 00:13:17 +03:00

69 lines
1.7 KiB
Ruby

# frozen_string_literal: true
describe "find-method" do
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 matching methods by name regex (-n option)" do
it "should find a method by regex" do
expect(pry_eval(binding, "find-method hell MyKlass")).to match(
/MyKlass.*?hello/m
)
end
it "should NOT match a method that does not match the regex" do
expect(pry_eval(binding, "find-method hell MyKlass")).not_to match(
/MyKlass.*?goodbye/m
)
end
end
describe "find matching methods by content regex (-c option)" do
it "should find a method by regex" do
expect(pry_eval(binding, "find-method -c timothy MyKlass")).to match(
/MyKlass.*?hello/m
)
end
it "should NOT match a method that does not match the regex" do
expect(pry_eval(binding, "find-method timothy MyKlass")).not_to match(
/MyKlass.*?goodbye/m
)
end
end
it "should work with badly behaved constants" do
MyKlass::X = Object.new
def (MyKlass::X).hash
raise "mooo"
end
expect(pry_eval(binding, "find-method -c timothy MyKlass")).to match(
/MyKlass.*?hello/m
)
end
it "should escape regexes correctly" do
good = /tea_time\?/
bad = /tea_tim\?/
expect(pry_eval(binding, 'find-method tea_time? MyKlass')).to match(good)
expect(pry_eval(binding, 'find-method tea_time? MyKlass')).to match(good)
expect(pry_eval(binding, 'find-method tea_time\? MyKlass')).not_to match(bad)
expect(pry_eval(binding, 'find-method tea_time\? MyKlass')).to match(good)
end
end