require 'helper' describe Pry do describe "output failsafe" do after do Pry.config.print = Pry::DEFAULT_PRINT end it "should catch serialization exceptions" do Pry.config.print = lambda { |*a| raise "catch-22" } lambda { mock_pry("1") }.should.not.raise end it "should display serialization exceptions" do Pry.config.print = lambda { |*a| raise "catch-22" } mock_pry("1").should =~ /\(pry\) output error: #/ end it "should catch errors serializing exceptions" do Pry.config.print = lambda do |*a| raise Exception.new("catch-22").tap{ |e| class << e; def inspect; raise e; end; end } end mock_pry("1").should =~ /\(pry\) output error: failed to show result/ end end describe "DEFAULT_PRINT" do it "should output the right thing" do mock_pry("{:a => 1}").should =~ /\{:a=>1\}/ end it "should not be phased by un-inspectable things" do mock_pry("class NastyClass; undef pretty_inspect; end", "NastyClass.new").should =~ /#/ end end describe "output suppression" do before do @t = pry_tester end it "should normally output the result" do mock_pry("1 + 2").should == "=> 3\n\n" end it "should not output anything if the input ends with a semicolon" do mock_pry("1 + 2;").should == "\n" end it "should output something if the input ends with a comment" do mock_pry("1 + 2 # basic addition").should == "=> 3\n\n" end it "should not output something if the input is only a comment" do mock_pry("# basic addition").should == "\n" end end end