Sha256: 906cd1d85edc0c7d819d628a3bfd8003199c130c8f3057e6497a626e4cf3e905

Contents?: true

Size: 739 Bytes

Versions: 13

Compression:

Stored size: 739 Bytes

Contents

require 'parallel_specs'
require File.join(File.dirname(__FILE__), 'spec_logger_base')

class ParallelSpecs::SpecRuntimeLogger < ParallelSpecs::SpecLoggerBase
  def initialize(options, output=nil)
    super
    @example_times = Hash.new(0)
  end

  def example_started(*args)
    @time = Time.now
  end

  def example_passed(example)
    file = example.location.split(':').first
    @example_times[file] += Time.now - @time
  end

  def start_dump(*args)
    return unless ENV['TEST_ENV_NUMBER'] #only record when running in parallel
    # TODO: Figure out why sometimes time can be less than 0
    lock_output do
      @output.puts @example_times.map { |file, time| "#{file}:#{time > 0 ? time : 0}" }
    end
    @output.flush
  end

end

Version data entries

13 entries across 13 versions & 2 rubygems

Version Path
parallel_tests-0.6.9 lib/parallel_specs/spec_runtime_logger.rb
parallel_tests-0.6.8 lib/parallel_specs/spec_runtime_logger.rb
parallel_tests-0.6.7 lib/parallel_specs/spec_runtime_logger.rb
parallel_tests-0.6.6 lib/parallel_specs/spec_runtime_logger.rb
parallel_tests-0.6.5 lib/parallel_specs/spec_runtime_logger.rb
parallel_tests-0.6.4 lib/parallel_specs/spec_runtime_logger.rb
parallel_tests-0.6.3 lib/parallel_specs/spec_runtime_logger.rb
parallel_tests-0.6.2 lib/parallel_specs/spec_runtime_logger.rb
phene-parallel_tests-0.6.2 lib/parallel_specs/spec_runtime_logger.rb
parallel_tests-0.6.1 lib/parallel_specs/spec_runtime_logger.rb
parallel_tests-0.6.0 lib/parallel_specs/spec_runtime_logger.rb
parallel_tests-0.5.0 lib/parallel_specs/spec_runtime_logger.rb
parallel_tests-0.4.21 lib/parallel_specs/spec_runtime_logger.rb