Class: Minitest::StatisticsReporter
- Inherits:
-
Reporter
- Object
- AbstractReporter
- Reporter
- Minitest::StatisticsReporter
- Defined in:
- lib/minitest.rb
Overview
A reporter that gathers statistics about a test run. Does not do any IO because meant to be used as a parent class for a reporter that does.
If you want to create an entirely different type of output (eg, CI, HTML, etc), this is the place to start.
Example:
class JenkinsCIReporter < StatisticsReporter
def report
super # Needed to calculate some statistics
print "<testsuite "
print "tests='#{count}' "
print "failures='#{failures}' "
# Remaining XML...
end
end
Direct Known Subclasses
Instance Attribute Summary collapse
-
#assertions ⇒ Object
Total number of assertions.
-
#count ⇒ Object
Total number of test cases.
-
#errors ⇒ Object
Total number of tests that erred.
-
#failures ⇒ Object
Total number of tests that failed.
-
#results ⇒ Object
An
Array
of test cases that failed or were skipped. -
#skips ⇒ Object
Total number of tests that where skipped.
-
#start_time ⇒ Object
Time the test run started.
-
#total_time ⇒ Object
Test run time.
-
#warnings ⇒ Object
Total number of tests that warned.
Attributes inherited from Reporter
Instance Method Summary collapse
-
#initialize(io = $stdout, options = {}) ⇒ StatisticsReporter
constructor
:nodoc:.
-
#passed? ⇒ Boolean
:nodoc:.
-
#record(result) ⇒ Object
:nodoc:.
-
#report ⇒ Object
Report on the tracked statistics.
-
#start ⇒ Object
:nodoc:.
Methods inherited from AbstractReporter
Constructor Details
#initialize(io = $stdout, options = {}) ⇒ StatisticsReporter
:nodoc:
843 844 845 846 847 848 849 850 851 852 853 854 855 |
# File 'lib/minitest.rb', line 843 def initialize io = $stdout, = {} # :nodoc: super self.assertions = 0 self.count = 0 self.results = [] self.start_time = nil self.total_time = nil self.failures = nil self.errors = nil self.warnings = nil self.skips = nil end |
Instance Attribute Details
#assertions ⇒ Object
Total number of assertions.
798 799 800 |
# File 'lib/minitest.rb', line 798 def assertions @assertions end |
#count ⇒ Object
Total number of test cases.
803 804 805 |
# File 'lib/minitest.rb', line 803 def count @count end |
#errors ⇒ Object
Total number of tests that erred.
831 832 833 |
# File 'lib/minitest.rb', line 831 def errors @errors end |
#failures ⇒ Object
Total number of tests that failed.
826 827 828 |
# File 'lib/minitest.rb', line 826 def failures @failures end |
#results ⇒ Object
An Array
of test cases that failed or were skipped.
808 809 810 |
# File 'lib/minitest.rb', line 808 def results @results end |
#skips ⇒ Object
Total number of tests that where skipped.
841 842 843 |
# File 'lib/minitest.rb', line 841 def skips @skips end |
#start_time ⇒ Object
Time the test run started. If available, the monotonic clock is used and this is a Float
, otherwise it’s an instance of Time
.
815 816 817 |
# File 'lib/minitest.rb', line 815 def start_time @start_time end |
#total_time ⇒ Object
Test run time. If available, the monotonic clock is used and this is a Float
, otherwise it’s an instance of Time
.
821 822 823 |
# File 'lib/minitest.rb', line 821 def total_time @total_time end |
#warnings ⇒ Object
Total number of tests that warned.
836 837 838 |
# File 'lib/minitest.rb', line 836 def warnings @warnings end |
Instance Method Details
#passed? ⇒ Boolean
:nodoc:
857 858 859 |
# File 'lib/minitest.rb', line 857 def passed? # :nodoc: results.all?(&:skipped?) end |
#record(result) ⇒ Object
:nodoc:
865 866 867 868 869 870 |
# File 'lib/minitest.rb', line 865 def record result # :nodoc: self.count += 1 self.assertions += result.assertions results << result if not result.passed? or result.skipped? end |
#report ⇒ Object
Report on the tracked statistics.
875 876 877 878 879 880 881 882 883 884 |
# File 'lib/minitest.rb', line 875 def report aggregate = results.group_by { |r| r.failure.class } aggregate.default = [] # dumb. group_by should provide this self.total_time = Minitest.clock_time - start_time self.failures = aggregate[Assertion].size self.errors = aggregate[UnexpectedError].size self.warnings = aggregate[UnexpectedWarning].size self.skips = aggregate[Skip].size end |
#start ⇒ Object
:nodoc:
861 862 863 |
# File 'lib/minitest.rb', line 861 def start # :nodoc: self.start_time = Minitest.clock_time end |