2013-11-22 19:36:18 -05:00
|
|
|
describe "watch expression" do
|
|
|
|
# Custom eval that will:
|
|
|
|
# 1) Create an instance of pry that can use for multiple calls
|
|
|
|
# 2) Exercise the after_eval hook
|
|
|
|
# 3) Return the output
|
|
|
|
def eval(expr)
|
|
|
|
output = @tester.eval expr
|
2014-01-24 03:16:16 -05:00
|
|
|
@tester.pry.hooks.exec_hook :after_eval, nil, @tester.pry
|
2013-11-22 19:36:18 -05:00
|
|
|
output
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
|
|
|
@tester = pry_tester
|
2015-03-14 04:08:16 -04:00
|
|
|
@tester.pry.hooks.clear_event_hooks(:after_eval)
|
2013-11-22 19:36:18 -05:00
|
|
|
eval "watch --delete"
|
|
|
|
end
|
|
|
|
|
2014-01-24 02:00:12 -05:00
|
|
|
it "registers the after_eval hook" do
|
2013-11-22 19:36:18 -05:00
|
|
|
eval 'watch 1+1'
|
2015-03-10 16:49:29 -04:00
|
|
|
expect(@tester.pry.hooks.hook_exists?(:after_eval, :watch_expression)).to eq(true)
|
2013-11-22 19:36:18 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
it "prints no watched expressions" do
|
2015-03-10 16:49:29 -04:00
|
|
|
expect(eval('watch')).to match(/No watched expressions/)
|
2013-11-22 19:36:18 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
it "watches an expression" do
|
|
|
|
eval "watch 1+1"
|
2015-03-10 16:49:29 -04:00
|
|
|
expect(eval('watch')).to match(/=> 2/)
|
2013-11-22 19:36:18 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
it "watches a local variable" do
|
|
|
|
eval 'foo = :bar'
|
|
|
|
eval 'watch foo'
|
2015-03-10 16:49:29 -04:00
|
|
|
expect(eval('watch')).to match(/=> :bar/)
|
2013-11-22 19:36:18 -05:00
|
|
|
end
|
|
|
|
|
2014-01-24 02:00:20 -05:00
|
|
|
it "prints when an expression changes" do
|
|
|
|
ReplTester.start do
|
|
|
|
input 'a = 1'
|
|
|
|
output '=> 1'
|
|
|
|
|
|
|
|
input 'watch a'
|
|
|
|
output "Watching a\nwatch: a => 1"
|
|
|
|
|
|
|
|
input "a = 2"
|
|
|
|
output "watch: a => 2\n=> 2"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2014-02-04 13:55:06 -05:00
|
|
|
it "prints when an expression is mutated" do
|
|
|
|
ReplTester.start do
|
|
|
|
input 'a = "one"'
|
|
|
|
output '=> "one"'
|
|
|
|
|
|
|
|
input 'watch a'
|
|
|
|
output %(Watching a\nwatch: a => "one")
|
|
|
|
|
|
|
|
input "a.sub! 'o', 'p'"
|
|
|
|
output %(watch: a => "pne"\n=> "pne")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2014-01-24 02:00:20 -05:00
|
|
|
it "doesn't print when an expresison remains the same" do
|
|
|
|
ReplTester.start do
|
|
|
|
input 'a = 1'
|
|
|
|
output '=> 1'
|
|
|
|
|
|
|
|
input 'watch a'
|
|
|
|
output "Watching a\nwatch: a => 1"
|
|
|
|
|
|
|
|
input "a = 1"
|
|
|
|
output "=> 1"
|
|
|
|
end
|
|
|
|
end
|
2013-11-22 19:36:18 -05:00
|
|
|
|
2014-01-24 02:36:46 -05:00
|
|
|
it "continues to work if you start a second pry instance" do
|
|
|
|
ReplTester.start do
|
|
|
|
input 'a = 1'
|
|
|
|
output '=> 1'
|
|
|
|
|
|
|
|
input 'watch a'
|
|
|
|
output "Watching a\nwatch: a => 1"
|
|
|
|
|
|
|
|
input "a = 2"
|
|
|
|
output "watch: a => 2\n=> 2"
|
|
|
|
end
|
|
|
|
|
|
|
|
ReplTester.start do
|
|
|
|
input 'b = 1'
|
|
|
|
output '=> 1'
|
|
|
|
|
|
|
|
input 'watch b'
|
|
|
|
output "Watching b\nwatch: b => 1"
|
|
|
|
|
|
|
|
input "b = 2"
|
|
|
|
output "watch: b => 2\n=> 2"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-11-22 19:36:18 -05:00
|
|
|
describe "deleting expressions" do
|
|
|
|
before do
|
|
|
|
eval 'watch :keeper'
|
|
|
|
eval 'watch :delete'
|
|
|
|
eval 'watch -d 2'
|
|
|
|
end
|
|
|
|
|
|
|
|
it "keeps keeper" do
|
2015-03-10 16:49:29 -04:00
|
|
|
expect(eval('watch')).to match(/keeper/)
|
2013-11-22 19:36:18 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
it "deletes delete" do
|
2015-03-10 16:49:29 -04:00
|
|
|
expect(eval('watch')).not_to match(/delete/)
|
2013-11-22 19:36:18 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|