Class: Henitai::Integration::ScenarioLogSupport
- Inherits:
-
Object
- Object
- Henitai::Integration::ScenarioLogSupport
- Defined in:
- lib/henitai/integration.rb,
lib/henitai/integration.rb
Overview
Stores the child-process log helpers shared by the integration specs.
Instance Method Summary collapse
- #build_child_output_files(log_paths) ⇒ Object
- #capture_child_output(log_paths) ⇒ Object
- #close_child_output(output_files) ⇒ Object
- #close_child_output_files(output_files) ⇒ Object
- #combined_log(stdout, stderr) ⇒ Object
- #open_child_output(log_paths) ⇒ Object
- #read_log_file(path) ⇒ Object
- #redirect_child_output(output_files) ⇒ Object
- #reopen_child_output_stream(stream, original_stream) ⇒ Object
- #restore_child_output(output_files) ⇒ Object
- #sync_child_output_files(output_files) ⇒ Object
- #with_coverage_dir(mutant_id) ⇒ Object
- #write_combined_log(path, stdout, stderr) ⇒ Object
Instance Method Details
#build_child_output_files(log_paths) ⇒ Object
58 59 60 61 62 63 64 65 |
# File 'lib/henitai/integration.rb', line 58 def build_child_output_files(log_paths) { original_stdout: stdout_stream.dup, original_stderr: stderr_stream.dup, stdout_file: File.new(log_paths[:stdout_path], "w"), stderr_file: File.new(log_paths[:stderr_path], "w") } end |
#capture_child_output(log_paths) ⇒ Object
24 25 26 27 28 29 |
# File 'lib/henitai/integration.rb', line 24 def capture_child_output(log_paths) output_files = open_child_output(log_paths) yield ensure close_child_output(output_files) end |
#close_child_output(output_files) ⇒ Object
51 52 53 54 55 56 |
# File 'lib/henitai/integration.rb', line 51 def close_child_output(output_files) return unless output_files restore_child_output(output_files) close_child_output_files(output_files) end |
#close_child_output_files(output_files) ⇒ Object
90 91 92 93 94 |
# File 'lib/henitai/integration.rb', line 90 def close_child_output_files(output_files) %i[stdout_file stderr_file original_stdout original_stderr].each do |key| output_files[key]&.close end end |
#combined_log(stdout, stderr) ⇒ Object
466 467 468 469 470 471 |
# File 'lib/henitai/integration.rb', line 466 def combined_log(stdout, stderr) [ (stdout.empty? ? nil : "stdout:\n#{stdout}"), (stderr.empty? ? nil : "stderr:\n#{stderr}") ].compact.join("\n") end |
#open_child_output(log_paths) ⇒ Object
43 44 45 46 47 48 49 |
# File 'lib/henitai/integration.rb', line 43 def open_child_output(log_paths) FileUtils.mkdir_p(File.dirname(log_paths[:log_path])) output_files = build_child_output_files(log_paths) sync_child_output_files(output_files) redirect_child_output(output_files) output_files end |
#read_log_file(path) ⇒ Object
455 456 457 458 459 |
# File 'lib/henitai/integration.rb', line 455 def read_log_file(path) return "" unless File.exist?(path) File.read(path) end |
#redirect_child_output(output_files) ⇒ Object
72 73 74 75 76 77 |
# File 'lib/henitai/integration.rb', line 72 def redirect_child_output(output_files) reopen_child_output_stream(stdout_stream, output_files[:stdout_file]) reopen_child_output_stream(stderr_stream, output_files[:stderr_file]) $stdout = stdout_stream $stderr = stderr_stream end |
#reopen_child_output_stream(stream, original_stream) ⇒ Object
86 87 88 |
# File 'lib/henitai/integration.rb', line 86 def reopen_child_output_stream(stream, original_stream) stream.reopen(original_stream) if original_stream end |
#restore_child_output(output_files) ⇒ Object
79 80 81 82 83 84 |
# File 'lib/henitai/integration.rb', line 79 def restore_child_output(output_files) reopen_child_output_stream(stdout_stream, output_files[:original_stdout]) reopen_child_output_stream(stderr_stream, output_files[:original_stderr]) $stdout = output_files[:original_stdout] $stderr = output_files[:original_stderr] end |
#sync_child_output_files(output_files) ⇒ Object
67 68 69 70 |
# File 'lib/henitai/integration.rb', line 67 def sync_child_output_files(output_files) output_files[:stdout_file].sync = true output_files[:stderr_file].sync = true end |
#with_coverage_dir(mutant_id) ⇒ Object
31 32 33 34 35 36 37 38 39 40 41 |
# File 'lib/henitai/integration.rb', line 31 def with_coverage_dir(mutant_id) original_coverage_dir = ENV.fetch("HENITAI_COVERAGE_DIR", nil) ENV["HENITAI_COVERAGE_DIR"] = mutation_coverage_dir(mutant_id) yield ensure if original_coverage_dir.nil? ENV.delete("HENITAI_COVERAGE_DIR") else ENV["HENITAI_COVERAGE_DIR"] = original_coverage_dir end end |
#write_combined_log(path, stdout, stderr) ⇒ Object
461 462 463 464 |
# File 'lib/henitai/integration.rb', line 461 def write_combined_log(path, stdout, stderr) FileUtils.mkdir_p(File.dirname(path)) File.write(path, combined_log(stdout, stderr)) end |