[#54738] [ruby-trunk - Bug #8358][Open] TestSprintf#test_float test failuer on mingw32 — "phasis68 (Heesob Park)" <phasis@...>

36 messages 2013/05/02

[#54749] [ruby-trunk - Feature #8361][Open] Alternative syntax for block parameter — "alexeymuranov (Alexey Muranov)" <redmine@...>

12 messages 2013/05/02

[#54798] [ruby-trunk - Bug #8370][Open] Constants MAX_MULTIPART_LENGTH in cgi\core.rb — "xibbar (Takeyuki FUJIOKA)" <xibbar@...>

17 messages 2013/05/05

[#54850] [ruby-trunk - Feature #8377][Open] Deprecate :: for method calls in 2.1 — "charliesome (Charlie Somerville)" <charliesome@...>

27 messages 2013/05/07

[#54881] [ruby-trunk - Bug #8384][Open] Cannot build ruby against OpenSSL build with "no-ec2m" — "vo.x (Vit Ondruch)" <v.ondruch@...>

16 messages 2013/05/09

[#54921] [ruby-trunk - Bug #8393][Open] A class who's parent class is in a module can go wrong if files are required in the wrong order — "eLobato (Daniel Lobato Garcia)" <elobatocs@...>

15 messages 2013/05/12

[#54939] [ruby-trunk - Bug #8399][Open] Remove usage of RARRAY_PTR in C extensions when not needed — "dbussink (Dirkjan Bussink)" <d.bussink@...>

32 messages 2013/05/12

[#55053] [ruby-trunk - Feature #8426][Open] Implement class hierarchy method caching — "charliesome (Charlie Somerville)" <charliesome@...>

21 messages 2013/05/19

[#55096] [ruby-trunk - Feature #8430][Open] Rational number literal — "mrkn (Kenta Murata)" <muraken@...>

28 messages 2013/05/21

[#55197] [ruby-trunk - Feature #8461][Open] Easy way to disable certificate checking in XMLRPC::Client — "herwinw (Herwin Weststrate)" <herwin@...>

11 messages 2013/05/29

[ruby-core:54836] [ruby-trunk - Bug #8366] Exception.message take time to execute depending on the instance variables

From: "anuraguniyal (anurag uniyal)" <anuraguniyal@...>
Date: 2013-05-06 18:01:36 UTC
List: ruby-core #54836
Issue #8366 has been updated by anuraguniyal (anurag uniyal).


nobu (Nobuyoshi Nakada) wrote:
> You should define inspect method.

But it is not practical to define inspect on all the classes I write or  add inspect to all third party code or plugins I use, easier and better solution would be to now have obj.inspect called for ex.message
----------------------------------------
Bug #8366: Exception.message take time to execute depending on the instance variables
https://bugs.ruby-lang.org/issues/8366#change-39170

Author: anuraguniyal (anurag uniyal)
Status: Open
Priority: Low
Assignee: 
Category: 
Target version: 
ruby -v: ruby 1.9.2p290 (2011-07-09 revision 32553) [x86_64-darwin11.4.2]
Backport: 1.9.3: UNKNOWN, 2.0.0: UNKNOWN


I am seeing very interesting and catastrophic behavior with ruby, see the code below

    class ExceptionTest
    
      def test
        @result = [0]*500000
    
        begin
          no_such_method
        rescue Exception => ex
          puts "before #{ex.class}"
          st = Time.now
          ex.message
          puts "after #{Time.now-st} #{ex.message}"
        end
    
      end
    end
    
    ExceptionTest.new.test

Ideally ex.message should not take any time to execute and hence Time taken should be in ms, but here is the output

    ruby 1.9.2p290 (2011-07-09 revision 32553) [x86_64-darwin11.4.2]
    before NameError
    after 0.462443 undefined local variable or method `no_such_method' for #<ExceptionTest:0x007fc74a84e4f0>

If I assign `[0]*500000` to a local variable instead of instance variable e.g. `result = [0]*500000` it runs as expected

    ruby 1.9.2p290 (2011-07-09 revision 32553) [x86_64-darwin11.4.2]
    before NameError
    after 2.8e-05 undefined local variable or method `no_such_method' for #<ExceptionTest:0x007ff59204e518>

**It looks like somehow `ex.message` is looping thru the instance variables, why it would do so, please enlighten me!**

I have tried it on ruby ruby-1.9.2-p290, ruby-1.9.1-p376 and whatever version the ruby on codepad.org is.



-- 
http://bugs.ruby-lang.org/

In This Thread