mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* thread.c (rb_exec_recursive_outer, rb_exec_recursive): Added method to short-circuit to the outermost level in case of recursion
* test/ruby/test_thread.rb (test_recursive_outer): Test for above * hash.c (rb_hash_hash): Return a sensible hash for in case of recursion [ruby-core:24648] * range.c (rb_range_hash): ditto * struct.c (rb_struct_hash): ditto * array.c (rb_array_hash): ditto * test/ruby/test_array.rb (test_hash2): test for above git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@24943 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
6a54d4b6fe
commit
1796522f10
9 changed files with 133 additions and 45 deletions
|
@ -458,6 +458,19 @@ class TestThread < Test::Unit::TestCase
|
|||
end
|
||||
assert_raise(TypeError) { [o].inspect }
|
||||
end
|
||||
|
||||
def test_recursive_outer
|
||||
arr = []
|
||||
obj = Struct.new(:foo, :visited).new(arr, false)
|
||||
arr << obj
|
||||
def obj.hash
|
||||
self[:visited] = true
|
||||
super
|
||||
raise "recursive_outer should short circuit intermediate calls"
|
||||
end
|
||||
assert_nothing_raised {arr.hash}
|
||||
assert(obj[:visited])
|
||||
end
|
||||
end
|
||||
|
||||
class TestThreadGroup < Test::Unit::TestCase
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue