Issue #7676 has been updated by hasari (Hiro Asari).


I, too, found documentation still lacking. I read #1720, and I understand the rationale for the Float::NAN case.

However, the issue still remains as Simon pointed out above. Please reopen the issue, or update the documentation to reflect the behavior more closely.
----------------------------------------
Bug #7676: Comparison of Float::NAN in array behaves unexpectedly
https://bugs.ruby-lang.org/issues/7676#change-35309

Author: simonrussell (Simon Russell)
Status: Rejected
Priority: Normal
Assignee: 
Category: 
Target version: 
ruby -v: ruby 1.9.3p362 (2012-12-25 revision 38607) [x86_64-linux]


It seems that two arrays containing Float::NAN will be considered equal ([Float::NAN] == [Float::NAN]), despite the fact that Float::NAN != Float::NAN.

Tested and reproduced in 1.8.7p371, 1.9.3p362, 2.0.0preview2. (This bug can be reproduced in Ruby 1.8 as well.)  Results below.

1.8.7 p371
---------

1.8.7 :001 > nan = 0.0/0.0
 => NaN 
1.8.7 :002 > nan == nan
 => false 
1.8.7 :003 > [nan] == [nan]
 => true 

1.9.3 p362
---------

1.9.3p362 :001 > Float::NAN == Float::NAN
 => false 
1.9.3p362 :002 > [Float::NAN] == [Float::NAN]
 => true 

2.0.0 preview2
--------------

2.0.0dev :001 > Float::NAN == Float::NAN
 => false 
2.0.0dev :002 > [Float::NAN] == [Float::NAN]
 => true


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