Sha256: 15bb4cb14ed2e4c12fdbaafe0c837f658c7aa59ec139a4f2d29dea6f49517f77

Contents?: true

Size: 899 Bytes

Versions: 3

Compression:

Stored size: 899 Bytes

Contents

require 'parallel_tests/spec/logger_base'

class ParallelTests::Spec::RuntimeLogger < ParallelTests::Spec::LoggerBase
  def initialize(*args)
    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 dump_summary(*args);end
  def dump_failures(*args);end
  def dump_failure(*args);end
  def dump_pending(*args);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
      @example_times.each do |file, time|
        relative_path = file.sub(/^#{Regexp.escape Dir.pwd}\//,'')
        @output.puts "#{relative_path}:#{time > 0 ? time : 0}"
      end
    end
    @output.flush
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
parallel_tests-0.7.0.rc1 lib/parallel_tests/spec/runtime_logger.rb
parallel_tests-0.7.0.alpha2 lib/parallel_tests/spec/runtime_logger.rb
parallel_tests-0.7.0.alpha lib/parallel_tests/spec/runtime_logger.rb