class MarkdownSummary
Generates a Markdown coverage summary.
Definitions
def initialize(threshold: 1.0)
Initialize the report with an optional coverage threshold.
Signature
-
parameter
thresholdNumeric | Nil The minimum ratio a file must meet to be omitted from the detailed output.
Implementation
def initialize(threshold: 1.0)
@threshold = threshold
end
def each(wrapper)
Enumerate coverage below the threshold and return aggregate statistics.
Signature
-
parameter
wrapperCovered::Base The coverage wrapper to enumerate.
-
yields
{|coverage| ...} Coverage whose ratio is below the configured threshold.
-
parameter
coverageCovered::Coverage The coverage object below the threshold.
-
parameter
-
returns
Covered::Statistics Statistics for all coverage objects, including omitted ones.
Implementation
def each(wrapper)
statistics = Statistics.new
wrapper.each do |coverage|
statistics << coverage
if @threshold.nil? or coverage.ratio < @threshold
yield coverage
end
end
return statistics
end
def print_annotations(output, coverage, line, line_offset)
Print any annotations for the given line.
Signature
-
parameter
outputIO The output stream.
-
parameter
coverageCovered::Coverage The coverage being rendered.
-
parameter
lineString The source line.
-
parameter
line_offsetInteger The current line number.
Implementation
def print_annotations(output, coverage, line, line_offset)
if annotations = coverage.annotations[line_offset]
prefix = "#{line_offset}|".rjust(8) + "*|".rjust(8)
output.write prefix
output.write line.match(/^\s+/)
output.puts "\# #{annotations.join(", ")}"
end
end
def print_line_header(output)
Print the line and hit-count header.
Signature
-
parameter
outputIO The output stream.
Implementation
def print_line_header(output)
output.puts "Line|".rjust(8) + "Hits|".rjust(8)
end
def print_line(output, line, line_offset, count)
Print a single source line.
Signature
-
parameter
outputIO The output stream.
-
parameter
lineString The source line.
-
parameter
line_offsetInteger The current line number.
-
parameter
countInteger | Nil The execution count for the line.
Implementation
def print_line(output, line, line_offset, count)
prefix = "#{line_offset}|".rjust(8) + "#{count}|".rjust(8)
output.write prefix
output.write line
# If there was no newline at end of file, we add one:
unless line.end_with?($/)
output.puts
end
end
def call(wrapper, output = $stdout)
A coverage array gives, for each line, the number of line executions by the interpreter. A nil value means coverage is finished for this line (lines like else and end).
Signature
-
parameter
wrapperCovered::Base The coverage wrapper to report.
-
parameter
outputIO The output stream.
Implementation
def call(wrapper, output = $stdout)
output.puts "# Coverage Report"
output.puts
ordered = []
buffer = StringIO.new
statistics = self.each(wrapper) do |coverage|
ordered << coverage unless coverage.complete?
end
statistics.print(output)
if ordered.any?
output.puts "", "\#\# Least Coverage:", ""
ordered.sort_by!(&:missing_count).reverse!
ordered.first(5).each do |coverage|
path = wrapper.relative_path(coverage.path)
output.puts "- `#{path}`: #{coverage.missing_count} lines not executed!"
end
end
output.print(buffer.string)
end