Sha256: 23022a92842dbc2c2a2c69346b4a1dde6064279e30f9756c5f601413fb5c32e1

Contents?: true

Size: 1.57 KB

Versions: 196

Compression:

Stored size: 1.57 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
              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

196 entries across 134 versions & 39 rubygems

Version Path
minitest-5.21.0 lib/minitest/parallel.rb
getargv-0.3.3-universal-darwin vendor/bundle/ruby/3.3.0/gems/minitest-5.20.0/lib/minitest/parallel.rb
direct7-0.0.11 vendor/bundle/ruby/2.7.0/gems/minitest-5.20.0/lib/minitest/parallel.rb
direct7-0.0.11 vendor/bundle/ruby/3.0.0/gems/minitest-5.20.0/lib/minitest/parallel.rb
scrapbook-0.3.2 vendor/ruby/2.7.0/gems/minitest-5.16.3/lib/minitest/parallel.rb
scrapbook-0.3.2 vendor/ruby/2.7.0/gems/minitest-5.18.1/lib/minitest/parallel.rb
scrapbook-0.3.2 vendor/ruby/2.7.0/gems/minitest-5.15.0/lib/minitest/parallel.rb
scrapbook-0.3.2 vendor/ruby/2.7.0/gems/minitest-5.16.2/lib/minitest/parallel.rb
minitest-5.20.0 lib/minitest/parallel.rb
minitest-5.19.0 lib/minitest/parallel.rb
mlh-rubocop-config-1.0.2 vendor/bundle/ruby/3.2.0/gems/minitest-5.18.1/lib/minitest/parallel.rb
fablicop-1.10.3 vendor/bundle/ruby/3.2.0/gems/minitest-5.18.0/lib/minitest/parallel.rb
fablicop-1.10.3 vendor/bundle/ruby/3.2.0/gems/minitest-5.18.1/lib/minitest/parallel.rb
scrapbook-0.3.1 vendor/ruby/2.7.0/gems/minitest-5.16.2/lib/minitest/parallel.rb
scrapbook-0.3.1 vendor/ruby/2.7.0/gems/minitest-5.15.0/lib/minitest/parallel.rb
scrapbook-0.3.1 vendor/ruby/2.7.0/gems/minitest-5.16.3/lib/minitest/parallel.rb
scrapbook-0.3.1 vendor/ruby/2.7.0/gems/minitest-5.18.1/lib/minitest/parallel.rb
rubypitaya-3.12.5 ./lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/minitest-5.17.0/lib/minitest/parallel.rb
minitest-5.18.1 lib/minitest/parallel.rb
fablicop-1.10.2 vendor/bundle/ruby/3.2.0/gems/minitest-5.18.0/lib/minitest/parallel.rb