Sha256: a5f471d54233be651a0c06a3182bec45fa580e9918ff336a7cca7626110f0e60

Contents?: true

Size: 1.58 KB

Versions: 5

Compression:

Stored size: 1.58 KB

Contents

module Minitest
  module Parallel # :nodoc:

    ##
    # The engine used to run multiple tests in parallel.

    class Executor

      ##
      # The size of the pool of workers.

      attr_reader :size

      ##
      # Create a parallel test executor of with +size+ workers.

      def initialize size
        @size  = size
        @queue = Thread::Queue.new
        @pool  = nil
      end

      ##
      # Start the executor

      def start
        @pool  = Array.new(size) {
          Thread.new @queue do |queue|
            Thread.current.abort_on_exception = true
            while job = queue.pop do
              klass, method, reporter = job
              reporter.synchronize { reporter.prerecord klass, method }
              result = Minitest.run_one_method klass, method
              reporter.synchronize { reporter.record result }
            end
          end
        }
      end

      ##
      # Add a job to the queue

      def << work; @queue << work; end

      ##
      # Shuts down the pool of workers by signalling them to quit and
      # waiting for them all to finish what they're currently working
      # on.

      def shutdown
        size.times { @queue << nil }
        @pool.each(&:join)
      end
    end

    module Test # :nodoc:
      def _synchronize; Minitest::Test.io_lock.synchronize { yield }; end # :nodoc:

      module ClassMethods # :nodoc:
        def run_one_method klass, method_name, reporter
          Minitest.parallel_executor << [klass, method_name, reporter]
        end

        def test_order
          :parallel
        end
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
minitest-5.25.4 lib/minitest/parallel.rb
minitest-5.25.3 lib/minitest/parallel.rb
minitest-5.25.2 lib/minitest/parallel.rb
minitest-5.25.1 lib/minitest/parallel.rb
minitest-5.25.0 lib/minitest/parallel.rb