Sha256: a1cf6b05f8945b117faf6ea116aa2885bba61ae9d0e57acbbe282f27f2a4cf0f
Contents?: true
Size: 882 Bytes
Versions: 1
Compression:
Stored size: 882 Bytes
Contents
class MultithreadingTest < Minitest::Test CustomError = Class.new StandardError def setup @operation = Orchestra.define do node :map_thread_ids do iterates_over :list provides :thread_ids perform do |item| raise CustomError, "blow up" if item == :blow_up Thread.current.object_id end end self.result = :thread_ids end @conductor = Orchestra::Conductor.new @conductor.thread_count = 5 end def test_multithreading list = (1..100).to_a thread_ids = @conductor.perform @operation, :list => list assert thread_ids.uniq.size > 2, "performance must be spread across threads" end def test_exception_during_multithreading list = (1..100).to_a list[23] = :blow_up assert_raises CustomError do @conductor.perform @operation, :list => list end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
ntl-orchestra-0.9.0 | test/integration/multithreading_test.rb |