class TurboTests::JsonRowsFormatter
An RSpec formatter used for each subprocess during parallel test execution
def close(notification)
def close(notification) output_row( type: :close ) end
def example_failed(notification)
def example_failed(notification) output_row( type: :example_failed, example: example_to_json(notification.example) ) end
def example_group_finished(notification)
def example_group_finished(notification) output_row( type: :group_finished, group: group_to_json(notification) ) end
def example_group_started(notification)
def example_group_started(notification) output_row( type: :group_started, group: group_to_json(notification) ) end
def example_passed(notification)
def example_passed(notification) output_row( type: :example_passed, example: example_to_json(notification.example) ) end
def example_pending(notification)
def example_pending(notification) output_row( type: :example_pending, example: example_to_json(notification.example) ) end
def example_to_json(example)
def example_to_json(example) { execution_result: execution_result_to_json(example.execution_result), location: example.location, description: example.description, full_description: example.full_description, metadata: { shared_group_inclusion_backtrace: example .metadata[:shared_group_inclusion_backtrace] .map { |frame| stack_frame_to_json(frame) }, extra_failure_lines: example.metadata[:extra_failure_lines], }, location_rerun_argument: example.location_rerun_argument, } end
def exception_to_json(exception)
def exception_to_json(exception) if exception { class_name: exception.class.name.to_s, backtrace: exception.backtrace, message: exception.message, cause: exception_to_json(exception.cause) } end end
def execution_result_to_json(result)
def execution_result_to_json(result) { example_skipped?: result.example_skipped?, pending_message: result.pending_message, status: result.status, pending_fixed?: result.pending_fixed?, exception: exception_to_json(result.exception || result.pending_exception) } end
def group_to_json(notification)
def group_to_json(notification) { group: { description: notification.group.description } } end
def initialize(output)
def initialize(output) @output = output end
def load_summary_to_json(notification)
def load_summary_to_json(notification) { count: notification.count, load_time: notification.load_time, } end
def message(notification)
def message(notification) output_row( type: :message, message: notification.message ) end
def output_row(obj)
def output_row(obj) output.puts(obj.to_json) output.flush end
def seed(notification)
def seed(notification) output_row( type: :seed, seed: notification.seed ) end
def stack_frame_to_json(frame)
def stack_frame_to_json(frame) { shared_group_name: frame.shared_group_name, inclusion_location: frame.inclusion_location } end
def start(notification)
def start(notification) output_row( type: :load_summary, summary: load_summary_to_json(notification) ) end