summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorMarc-Andre Lafortune <github@marc-andre.ca>2020-12-21 23:31:11 -0500
committerMarc-André Lafortune <github@marc-andre.ca>2020-12-22 19:46:07 -0500
commitcd63f0358ffb43890d20bb5612c5d82be19fae62 (patch)
treef51341602bea8993177c7ba5cd08daaf220eee86 /test
parent3286380ebcc239b3fe1044884780162f1ee079fe (diff)
[ruby/etc] Make Ractor safe
Notes
Notes: Merged: https://github.com/ruby/ruby/pull/3954
Diffstat (limited to 'test')
-rw-r--r--test/etc/test_etc.rb23
1 files changed, 23 insertions, 0 deletions
diff --git a/test/etc/test_etc.rb b/test/etc/test_etc.rb
index d2ae9fa33c..dc224d0d32 100644
--- a/test/etc/test_etc.rb
+++ b/test/etc/test_etc.rb
@@ -169,4 +169,27 @@ class TestEtc < Test::Unit::TestCase
assert_operator(1, :<=, n)
end
+ def test_ractor
+ return unless Etc.passwd # => skip test if no platform support
+
+ assert_ractor(<<~RUBY, require: 'etc')
+ ractor = Ractor.new do
+ Etc.passwd do |s|
+ Ractor.yield :sync
+ Ractor.yield s.name
+ break :done
+ end
+ end
+ ractor.take # => :sync
+ assert_raise RuntimeError, /parallel/ do
+ Etc.passwd {}
+ end
+ name = ractor.take # => first name
+ ractor.take # => :done
+ name2 = Etc.passwd do |s|
+ break s.name
+ end
+ assert_equal(name2, name)
+ RUBY
+ end
end