diff options
author | Sean Griffin <sean@seantheprogrammer.com> | 2017-07-25 11:07:35 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-07-25 11:07:35 -0400 |
commit | a4154ea99f99634b972159a3c0d398c8c691a7f5 (patch) | |
tree | 40783c0a30112b4c75ae903672e8763c4930fae7 /test/test_nodes.rb | |
parent | 0e7ce3f4c7c17e72f905b26aff3893149f524888 (diff) | |
parent | 6d225a9870aea1fa25ab71774206d08d5b216355 (diff) | |
download | rails-a4154ea99f99634b972159a3c0d398c8c691a7f5.tar.gz rails-a4154ea99f99634b972159a3c0d398c8c691a7f5.tar.bz2 rails-a4154ea99f99634b972159a3c0d398c8c691a7f5.zip |
Merge pull request #490 from MaxLap/fix_nodes_hash_eql_eqeq
Add missing hash, eql?, == to various node classes
Diffstat (limited to 'test/test_nodes.rb')
-rw-r--r-- | test/test_nodes.rb | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/test/test_nodes.rb b/test/test_nodes.rb new file mode 100644 index 0000000000..bf0082396d --- /dev/null +++ b/test/test_nodes.rb @@ -0,0 +1,34 @@ +# frozen_string_literal: true +require 'helper' + +module Arel + module Nodes + class TestNodes < Minitest::Test + def test_every_arel_nodes_have_hash_eql_eqeq_from_same_class + # #descendants code from activesupport + node_descendants = [] + ObjectSpace.each_object(Arel::Nodes::Node.singleton_class) do |k| + next if k.respond_to?(:singleton_class?) && k.singleton_class? + node_descendants.unshift k unless k == self + end + node_descendants.delete(Arel::Nodes::Node) + + bad_node_descendants = node_descendants.reject do |subnode| + eqeq_owner = subnode.instance_method(:==).owner + eql_owner = subnode.instance_method(:eql?).owner + hash_owner = subnode.instance_method(:hash).owner + + eqeq_owner < Arel::Nodes::Node && + eqeq_owner == eql_owner && + eqeq_owner == hash_owner + end + + problem_msg = 'Some subclasses of Arel::Nodes::Node do not have a' \ + ' #== or #eql? or #hash defined from the same class as the others' + assert_empty bad_node_descendants, problem_msg + end + + + end + end +end |