Sha256: aea13751b810280b40c07a01a5df5d914ed19771b759a403d60e371f4bee5610

Contents?: true

Size: 1.05 KB

Versions: 3

Compression:

Stored size: 1.05 KB

Contents

require 'parallel_tests/spec/logger_base'
require 'parallel_tests/spec/runner'

class ParallelTests::Spec::FailuresLogger < ParallelTests::Spec::LoggerBase
  # RSpec 1: does not keep track of failures, so we do
  def example_failed(example, *args)
    if RSPEC_1
      @failed_examples ||= []
      @failed_examples << example
    else
      super
    end
  end

  # RSpec 1: dumps 1 failed spec
  def dump_failure(*args)
  end

  # RSpec 2: dumps all failed specs
  def dump_failures(*args)
  end

  def dump_summary(*args)
    lock_output do
      if RSPEC_1
        dump_commands_to_rerun_failed_examples_rspec_1
      else
        dump_commands_to_rerun_failed_examples
      end
    end
    @output.flush
  end

  private

  def dump_commands_to_rerun_failed_examples_rspec_1
    (@failed_examples||[]).each do |example|
      file, line = example.location.to_s.split(':')
      next unless file and line
      file.gsub!(%r(^.*?/spec/), './spec/')
      @output.puts "#{ParallelTests::Spec::Runner.executable} #{file}:#{line} # #{example.description}"
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

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