diff --git a/ChangeLog b/ChangeLog index 20488ef3be..c1a819475e 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,11 @@ +Mon Jul 29 21:15:30 2013 Akinori MUSHA + + * test/ruby/test_lazy_enumerator.rb + (TestLazyEnumerator#test_initialize): Make sure + Enumerator::Lazy#initialize raises error if the object is + frozen. The check was performed by rb_ivar_set() before + rb_check_frozen() was added to enumerator_init(). + Mon Jul 29 21:06:42 2013 Akinori MUSHA * enumerator.c (enumerator_init): Add a frozenness check to diff --git a/test/ruby/test_lazy_enumerator.rb b/test/ruby/test_lazy_enumerator.rb index 94b16a2841..1108b93706 100644 --- a/test/ruby/test_lazy_enumerator.rb +++ b/test/ruby/test_lazy_enumerator.rb @@ -22,6 +22,12 @@ class TestLazyEnumerator < Test::Unit::TestCase assert_equal([1, 2, 3], [1, 2, 3].lazy.to_a) assert_equal([1, 2, 3], Enumerator::Lazy.new([1, 2, 3]){|y, v| y << v}.to_a) assert_raise(ArgumentError) { Enumerator::Lazy.new([1, 2, 3]) } + + a = [1, 2, 3].lazy + a.freeze + assert_raise(RuntimeError) { + a.__send__ :initialize, [4, 5], &->(y, *v) { y << yield(*v) } + } end def test_each_args