class RSpec::Core::Formatters::JsonFormatter

@private

Attributes

output_hash[R]

Public Class Methods

new(output) click to toggle source
# File lib/rspec/core/formatters/json_formatter.rb, line 13
def initialize(output)
  super
  @output_hash = {
    :version => RSpec::Core::Version::STRING
  }
end

Public Instance Methods

close(_notification) click to toggle source
# File lib/rspec/core/formatters/json_formatter.rb, line 55
def close(_notification)
  output.write @output_hash.to_json
end
dump_profile(profile) click to toggle source
# File lib/rspec/core/formatters/json_formatter.rb, line 59
def dump_profile(profile)
  @output_hash[:profile] = {}
  dump_profile_slowest_examples(profile)
  dump_profile_slowest_example_groups(profile)
end
dump_profile_slowest_example_groups(profile) click to toggle source

@api private

# File lib/rspec/core/formatters/json_formatter.rb, line 78
def dump_profile_slowest_example_groups(profile)
  @output_hash[:profile] ||= {}
  @output_hash[:profile][:groups] = profile.slowest_groups.map do |loc, hash|
    hash.update(:location => loc)
  end
end
dump_profile_slowest_examples(profile) click to toggle source

@api private

# File lib/rspec/core/formatters/json_formatter.rb, line 66
def dump_profile_slowest_examples(profile)
  @output_hash[:profile] = {}
  @output_hash[:profile][:examples] = profile.slowest_examples.map do |example|
    format_example(example).tap do |hash|
      hash[:run_time] = example.execution_result.run_time
    end
  end
  @output_hash[:profile][:slowest] = profile.slow_duration
  @output_hash[:profile][:total] = profile.duration
end
dump_summary(summary) click to toggle source
# File lib/rspec/core/formatters/json_formatter.rb, line 24
def dump_summary(summary)
  @output_hash[:summary] = {
    :duration => summary.duration,
    :example_count => summary.example_count,
    :failure_count => summary.failure_count,
    :pending_count => summary.pending_count,
    :errors_outside_of_examples_count => summary.errors_outside_of_examples_count
  }
  @output_hash[:summary_line] = summary.totals_line
end
message(notification) click to toggle source
# File lib/rspec/core/formatters/json_formatter.rb, line 20
def message(notification)
  (@output_hash[:messages] ||= []) << notification.message
end
seed(notification) click to toggle source
# File lib/rspec/core/formatters/json_formatter.rb, line 50
def seed(notification)
  return unless notification.seed_used?
  @output_hash[:seed] = notification.seed
end
stop(notification) click to toggle source
# File lib/rspec/core/formatters/json_formatter.rb, line 35
def stop(notification)
  @output_hash[:examples] = notification.examples.map do |example|
    format_example(example).tap do |hash|
      e = example.exception
      if e
        hash[:exception] =  {
          :class => e.class.name,
          :message => e.message,
          :backtrace => e.backtrace,
        }
      end
    end
  end
end

Private Instance Methods

format_example(example) click to toggle source
# File lib/rspec/core/formatters/json_formatter.rb, line 87
def format_example(example)
  {
    :id => example.id,
    :description => example.description,
    :full_description => example.full_description,
    :status => example.execution_result.status.to_s,
    :file_path => example.metadata[:file_path],
    :line_number  => example.metadata[:line_number],
    :run_time => example.execution_result.run_time,
    :pending_message => example.execution_result.pending_message,
  }
end