Sha256: edf7b555e7c5f6b55b6008efefe47ec285c314d7aab9a1e528cd4461d9b5911c

Contents?: true

Size: 1.49 KB

Versions: 28

Compression:

Stored size: 1.49 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 = Queue.new
        @pool  = nil
      end

      ##
      # Start the executor

      def start
        @pool  = size.times.map {
          Thread.new(@queue) do |queue|
            Thread.current.abort_on_exception = true
            while (job = queue.pop)
              klass, method, reporter = job
              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
      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

28 entries across 26 versions & 7 rubygems

Version Path
tdiary-5.0.5 vendor/bundle/gems/minitest-5.10.1/lib/minitest/parallel.rb
tdiary-5.0.5 vendor/bundle/gems/tdiary-5.0.4/vendor/bundle/gems/minitest-5.10.1/lib/minitest/parallel.rb
tdiary-5.0.5 vendor/bundle/gems/minitest-5.10.2/lib/minitest/parallel.rb
minitest-5.10.2 lib/minitest/parallel.rb
enju_leaf-1.2.1 vendor/bundle/ruby/2.3/gems/minitest-5.10.1/lib/minitest/parallel.rb
lazy_record-0.2.1 vendor/bundle/gems/minitest-5.10.1/lib/minitest/parallel.rb
lazy_record-0.2.0 vendor/bundle/gems/minitest-5.10.1/lib/minitest/parallel.rb
lazy_record-0.1.9 vendor/bundle/gems/minitest-5.10.1/lib/minitest/parallel.rb
lazy_record-0.1.8 vendor/bundle/gems/minitest-5.10.1/lib/minitest/parallel.rb
lazy_record-0.1.7 vendor/bundle/gems/minitest-5.10.1/lib/minitest/parallel.rb
lazy_record-0.1.6 vendor/bundle/gems/minitest-5.10.1/lib/minitest/parallel.rb
lazy_record-0.1.4 vendor/bundle/gems/minitest-5.10.1/lib/minitest/parallel.rb
tdiary-5.0.4 vendor/bundle/gems/minitest-5.10.1/lib/minitest/parallel.rb
lazy_record-0.1.3 vendor/bundle/gems/minitest-5.10.1/lib/minitest/parallel.rb
lazy_record-0.1.2 vendor/bundle/gems/minitest-5.10.1/lib/minitest/parallel.rb
lazy_record-0.1.1 vendor/bundle/gems/minitest-5.10.1/lib/minitest/parallel.rb
lazy_record-0.1.0 vendor/bundle/gems/minitest-5.10.1/lib/minitest/parallel.rb
autocompl-0.2.2 test/dummy/vendor/bundle/ruby/2.3.0/gems/minitest-5.10.1/lib/minitest/parallel.rb
autocompl-0.2.1 test/dummy/vendor/bundle/ruby/2.3.0/gems/minitest-5.10.1/lib/minitest/parallel.rb
autocompl-0.2.0 test/dummy/vendor/bundle/ruby/2.3.0/gems/minitest-5.10.1/lib/minitest/parallel.rb