123456789_123456789_123456789_123456789_123456789_

Class: Rails::TestUnitReporter

Relationships & Source Files
Super Chains via Extension / Inclusion / Inheritance
Class Chain:
self, Minitest::StatisticsReporter
Instance Chain:
self, Minitest::StatisticsReporter
Inherits: Minitest::StatisticsReporter
  • ::Object
Defined in: railties/lib/rails/test_unit/reporter.rb

Constant Summary

Instance Attribute Summary

Instance Method Summary

Instance Attribute Details

#app_root (rw, private)

[ GitHub ]

  
# File 'railties/lib/rails/test_unit/reporter.rb', line 93

singleton_class.attr_accessor :app_root

#app_root=(value) (rw)

[ GitHub ]

  
# File 'railties/lib/rails/test_unit/reporter.rb', line 7

singleton_class.attr_accessor :app_root

#colored_output?Boolean (readonly, private)

[ GitHub ]

  
# File 'railties/lib/rails/test_unit/reporter.rb', line 102

def colored_output?
  options[:color] && io.respond_to?(:tty?) && io.tty?
end

#executable (rw)

[ GitHub ]

  
# File 'railties/lib/rails/test_unit/reporter.rb', line 10

singleton_class.attr_accessor :executable

#fail_fast?Boolean (readonly, private)

[ GitHub ]

  
# File 'railties/lib/rails/test_unit/reporter.rb', line 75

def fail_fast?
  options[:fail_fast]
end

#output_inline?Boolean (readonly, private)

[ GitHub ]

  
# File 'railties/lib/rails/test_unit/reporter.rb', line 71

def output_inline?
  options[:output_inline]
end

Instance Method Details

#aggregated_results

This method is for internal use only.
[ GitHub ]

  
# File 'railties/lib/rails/test_unit/reporter.rb', line 50

def aggregated_results # :nodoc:
  filtered_results.map { |result| format_rerun_snippet(result) }.join "\n"
end

#color_output(string, by:) (private)

[ GitHub ]

  
# File 'railties/lib/rails/test_unit/reporter.rb', line 114

def color_output(string, by:)
  if colored_output?
    "\e[#{COLOR_BY_RESULT_CODE[by.result_code]}m#{string}\e[0m"
  else
    string
  end
end

#filtered_results

[ GitHub ]

  
# File 'railties/lib/rails/test_unit/reporter.rb', line 54

def filtered_results
  if options[:verbose]
    results
  else
    results.reject(&:skipped?)
  end
end

#format_line(result) (private)

[ GitHub ]

  
# File 'railties/lib/rails/test_unit/reporter.rb', line 79

def format_line(result)
  "%.2f s = %s" % [result.time, result.result_code]
end

#format_rerun_snippet(result) (private)

[ GitHub ]

  
# File 'railties/lib/rails/test_unit/reporter.rb', line 83

def format_rerun_snippet(result)
  location, line = if result.respond_to?(:source_location)
    result.source_location
  else
    result.method(result.name).source_location
  end

  "#{self.class.executable} #{relative_path_for(location)}:#{line}"
end

#prerecord(test_class, test_name)

[ GitHub ]

  
# File 'railties/lib/rails/test_unit/reporter.rb', line 12

def prerecord(test_class, test_name)
  super
  if options[:verbose]
    io.print "%s#%s = " % [test_class.name, test_name]
  end
end

#record(result)

[ GitHub ]

  
# File 'railties/lib/rails/test_unit/reporter.rb', line 19

def record(result)
  super

  if options[:verbose]
    io.puts color_output(format_line(result), by: result)
  else
    io.print color_output(result.result_code, by: result)
  end

  if output_inline? && result.failure && (!result.skipped? || options[:verbose])
    io.puts
    io.puts
    io.puts color_output(result, by: result)
    io.puts
    io.puts format_rerun_snippet(result)
    io.puts
  end

  if fail_fast? && result.failure && !result.skipped?
    raise Interrupt
  end
end

#relative_path_for(file)

[ GitHub ]

  
# File 'railties/lib/rails/test_unit/reporter.rb', line 62

def relative_path_for(file)
  if app_root
    file.sub(/^#{app_root}\/?/, "")
  else
    file
  end
end

#report

[ GitHub ]

  
# File 'railties/lib/rails/test_unit/reporter.rb', line 42

def report
  return if output_inline? || filtered_results.empty?
  io.puts
  io.puts "Failed tests:"
  io.puts
  io.puts aggregated_results
end