Class: RSpec::Core::Formatters::HtmlSnippetExtractor Private
Do not use. This class is for internal use only.
Relationships & Source Files | |
Namespace Children | |
Modules:
| |
Inherits: | Object |
Defined in: | rspec-core/lib/rspec/core/formatters/html_snippet_extractor.rb |
Overview
Extracts code snippets by looking at the backtrace of the passed error and applies synax highlighting and line numbers using html.
Instance Method Summary
-
#lines_around(file, line) ⇒ String
Internal use only
Extract lines of code centered around a particular line within a source file.
-
#post_process(highlighted, offending_line) ⇒ String
Internal use only
Adds line numbers to all lines and highlights the line where the failure occurred using html
span
tags. -
#snippet(backtrace) ⇒ String
Internal use only
Extract lines of code corresponding to a backtrace.
-
#snippet_for(error_line) ⇒ String
Internal use only
Create a snippet from a line of code.
Instance Method Details
#lines_around(file, line) ⇒ String
Extract lines of code centered around a particular line within a source file.
# File 'rspec-core/lib/rspec/core/formatters/html_snippet_extractor.rb', line 84
def lines_around(file, line) if File.file?(file) lines = File.read(file).split("\n") min = [0, line - 3].max max = [line + 1, lines.length - 1].min selected_lines = [] selected_lines.join("\n") lines[min..max].join("\n") else "# Couldn't get snippet for #{file}" end rescue SecurityError # :nocov: - SecurityError is no longer produced starting in ruby 2.7 "# Couldn't get snippet for #{file}" # :nocov: end
#post_process(highlighted, offending_line) ⇒ String
Adds line numbers to all lines and highlights the line where the failure occurred using html span
tags.
# File 'rspec-core/lib/rspec/core/formatters/html_snippet_extractor.rb', line 110
def post_process(highlighted, offending_line) new_lines = [] highlighted.split("\n").each_with_index do |line, i| new_line = "<span class=\"linenum\">#{offending_line + i - 2}</span>#{line}" new_line = "<span class=\"offending\">#{new_line}</span>" if i == 2 new_lines << new_line end new_lines.join("\n") end
#snippet(backtrace) ⇒ String
Extract lines of code corresponding to a backtrace.
# File 'rspec-core/lib/rspec/core/formatters/html_snippet_extractor.rb', line 49
def snippet(backtrace) raw_code, line = snippet_for(backtrace[0]) highlighted = @@converter.convert(raw_code) post_process(highlighted, line) end
#snippet_for(error_line) ⇒ String
Create a snippet from a line of code.
# File 'rspec-core/lib/rspec/core/formatters/html_snippet_extractor.rb', line 65
def snippet_for(error_line) if error_line =~ /(.*):(\d+)/ file = Regexp.last_match[1] line = Regexp.last_match[2].to_i [lines_around(file, line), line] else ["# Couldn't get snippet for #{error_line}", 1] end end