2019-06-20 21:33:41 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2019-06-20 20:59:01 -04:00
|
|
|
module TurboTests
|
|
|
|
# An RSpec formatter used for each subprocess during parallel test execution
|
|
|
|
class JsonRowsFormatter
|
|
|
|
RSpec::Core::Formatters.register(
|
|
|
|
self,
|
|
|
|
:close,
|
|
|
|
:example_failed,
|
|
|
|
:example_passed,
|
|
|
|
:example_pending,
|
2020-06-23 01:34:58 -04:00
|
|
|
:message,
|
2019-06-20 20:59:01 -04:00
|
|
|
:seed
|
|
|
|
)
|
|
|
|
|
|
|
|
attr_reader :output
|
|
|
|
|
|
|
|
def initialize(output)
|
|
|
|
@output = output
|
|
|
|
end
|
|
|
|
|
|
|
|
def exception_to_json(exception)
|
|
|
|
if exception
|
|
|
|
{
|
2019-06-27 06:43:12 -04:00
|
|
|
class_name: exception.class.name.to_s,
|
2019-06-20 20:59:01 -04:00
|
|
|
backtrace: exception.backtrace,
|
|
|
|
message: exception.message,
|
2019-06-27 06:37:23 -04:00
|
|
|
cause: exception_to_json(exception.cause)
|
2019-06-20 20:59:01 -04:00
|
|
|
}
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
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)
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
2019-08-29 07:40:06 -04:00
|
|
|
def stack_frame_to_json(frame)
|
|
|
|
{
|
|
|
|
shared_group_name: frame.shared_group_name,
|
|
|
|
inclusion_location: frame.inclusion_location
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
2019-06-20 20:59:01 -04:00
|
|
|
def example_to_json(example)
|
|
|
|
{
|
|
|
|
execution_result: execution_result_to_json(example.execution_result),
|
|
|
|
location: example.location,
|
|
|
|
full_description: example.full_description,
|
|
|
|
metadata: {
|
|
|
|
shared_group_inclusion_backtrace:
|
2019-08-29 07:40:06 -04:00
|
|
|
example
|
|
|
|
.metadata[:shared_group_inclusion_backtrace]
|
|
|
|
.map(&method(:stack_frame_to_json))
|
2019-06-20 20:59:01 -04:00
|
|
|
},
|
|
|
|
location_rerun_argument: example.location_rerun_argument
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
def example_passed(notification)
|
2019-06-20 21:33:41 -04:00
|
|
|
output_row(
|
2019-06-20 20:59:01 -04:00
|
|
|
type: :example_passed,
|
|
|
|
example: example_to_json(notification.example)
|
2019-06-20 21:33:41 -04:00
|
|
|
)
|
2019-06-20 20:59:01 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def example_pending(notification)
|
2019-06-20 21:33:41 -04:00
|
|
|
output_row(
|
2019-06-20 20:59:01 -04:00
|
|
|
type: :example_pending,
|
|
|
|
example: example_to_json(notification.example)
|
2019-06-20 21:33:41 -04:00
|
|
|
)
|
2019-06-20 20:59:01 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def example_failed(notification)
|
2019-06-20 21:33:41 -04:00
|
|
|
output_row(
|
2019-06-20 20:59:01 -04:00
|
|
|
type: :example_failed,
|
|
|
|
example: example_to_json(notification.example)
|
2019-06-20 21:33:41 -04:00
|
|
|
)
|
2019-06-20 20:59:01 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def seed(notification)
|
2019-06-20 21:33:41 -04:00
|
|
|
output_row(
|
2019-06-20 20:59:01 -04:00
|
|
|
type: :seed,
|
|
|
|
seed: notification.seed,
|
2019-06-20 21:33:41 -04:00
|
|
|
)
|
2019-06-20 20:59:01 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def close(notification)
|
2019-06-20 21:33:41 -04:00
|
|
|
output_row(
|
2019-06-20 20:59:01 -04:00
|
|
|
type: :close,
|
2019-06-20 21:33:41 -04:00
|
|
|
)
|
2019-06-20 20:59:01 -04:00
|
|
|
end
|
|
|
|
|
2020-06-23 01:34:58 -04:00
|
|
|
def message(notification)
|
|
|
|
output_row(
|
|
|
|
type: :message,
|
|
|
|
message: notification.message
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
2019-06-20 20:59:01 -04:00
|
|
|
private
|
|
|
|
|
|
|
|
def output_row(obj)
|
|
|
|
output.puts(obj.to_json)
|
|
|
|
output.flush
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|