class Minitest::ServerReporter

Public Class Methods

new(pid) click to toggle source
Calls superclass method
# File lib/minitest/server_plugin.rb, line 21
def initialize pid
  uri = Minitest::Server.path(pid)
  @mt_server = DRbObject.new_with_uri uri
  super()
end

Public Instance Methods

record(result) click to toggle source
# File lib/minitest/server_plugin.rb, line 31
def record result
  r = result
  c = r.class

  if defined?(Minitest::Result) && Minitest::Result === r then
    file, = r.source_location
    cn = r.klass
  else
    file, = r.method(r.name).source_location
    cn = c.name
  end

  sanitize r.failures

  @mt_server.result file, cn, r.name, r.failures, r.assertions, r.time
end
report() click to toggle source
# File lib/minitest/server_plugin.rb, line 79
def report
  @mt_server.report
end
sanitize(failures) click to toggle source
# File lib/minitest/server_plugin.rb, line 48
def sanitize failures
  failures.map! { |e|
    case e
    when Minitest::UnexpectedError then
      # embedded exception might not be able to be marshaled.
      bt = e.exception.backtrace

      ex = RuntimeError.new(e.exception.message)
      e.exception = ex
      ex.set_backtrace bt

      e = Minitest::UnexpectedError.new ex # ugh. some rails plugin. ugh.

      if ex.instance_variables.include? :@bindings then # web-console is Evil
        ex.instance_variable_set :@bindings, nil
        e.instance_variable_set  :@bindings, nil
      end
    when Minitest::Assertion then
      bt = e.backtrace
      e = e.class.new(e.message)
      e.set_backtrace bt
    when Minitest::Skip then
      # do nothing
    else
      warn "Unhandled exception type: #{e.class}\n\n#{e.inspect}"
    end

    e
  }
end
start() click to toggle source
# File lib/minitest/server_plugin.rb, line 27
def start
  @mt_server.start
end