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