1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48
|
# frozen_string_literal: true
module ParallelTests
module RSpec
end
end
require 'rspec/core/formatters/base_text_formatter'
class ParallelTests::RSpec::LoggerBase < RSpec::Core::Formatters::BaseTextFormatter
RSPEC_2 = RSpec::Core::Version::STRING.start_with?('2')
def initialize(*args)
super
@output ||= args[0]
case @output
when String # a path ?
FileUtils.mkdir_p(File.dirname(@output))
File.open(@output, 'w') {} # overwrite previous results
@output = File.open(@output, 'a')
when File # close and restart in append mode
@output.close
@output = File.open(@output.path, 'a')
end
end
# stolen from Rspec
def close(*)
@output.close if (IO === @output) & (@output != $stdout)
end
protected
# do not let multiple processes get in each others way
def lock_output
if @output.is_a?(File)
begin
@output.flock File::LOCK_EX
yield
ensure
@output.flock File::LOCK_UN
end
else
yield
end
end
end
|