-
-
Notifications
You must be signed in to change notification settings - Fork 763
/
html_formatter.rb
154 lines (131 loc) · 4.95 KB
/
html_formatter.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
RSpec::Support.require_rspec_core "formatters/base_text_formatter"
RSpec::Support.require_rspec_core "formatters/html_printer"
module RSpec
module Core
module Formatters
# @private
class HtmlFormatter < BaseFormatter
Formatters.register self, :start, :example_group_started, :start_dump,
:example_started, :example_passed, :example_failed,
:example_pending, :dump_summary
def initialize(output)
super(output)
@failed_examples = []
@example_group_number = 0
@example_number = 0
@header_red = nil
@printer = HtmlPrinter.new(output)
end
def start(notification)
super
@printer.print_html_start
@printer.flush
end
def example_group_started(notification)
super
@example_group_red = false
@example_group_number += 1
@printer.print_example_group_end unless example_group_number == 1
@printer.print_example_group_start(example_group_number,
notification.group.description,
notification.group.parent_groups.size)
@printer.flush
end
def start_dump(_notification)
@printer.print_example_group_end
@printer.flush
end
def example_started(_notification)
@example_number += 1
end
def example_passed(passed)
@printer.move_progress(percent_done)
@printer.print_example_passed(passed.example.description, passed.example.execution_result.run_time)
@printer.flush
end
def example_failed(failure)
@failed_examples << failure.example
unless @header_red
@header_red = true
@printer.make_header_red
end
unless @example_group_red
@example_group_red = true
@printer.make_example_group_header_red(example_group_number)
end
@printer.move_progress(percent_done)
example = failure.example
exception = failure.exception
exception_details = if exception
{
:message => exception.message,
:backtrace => failure.formatted_backtrace.join("\n")
}
else
false
end
extra = extra_failure_content(failure)
@printer.print_example_failed(
example.execution_result.pending_fixed,
example.description,
example.execution_result.run_time,
@failed_examples.size,
exception_details,
(extra == "") ? false : extra,
true
)
@printer.flush
end
def example_pending(pending)
example = pending.example
@printer.make_header_yellow unless @header_red
@printer.make_example_group_header_yellow(example_group_number) unless @example_group_red
@printer.move_progress(percent_done)
@printer.print_example_pending(example.description, example.execution_result.pending_message)
@printer.flush
end
def dump_summary(summary)
@printer.print_summary(
summary.duration,
summary.example_count,
summary.failure_count,
summary.pending_count
)
@printer.flush
end
private
# If these methods are declared with attr_reader Ruby will issue a
# warning because they are private.
# rubocop:disable Style/TrivialAccessors
# The number of the currently running example_group.
def example_group_number
@example_group_number
end
# The number of the currently running example (a global counter).
def example_number
@example_number
end
# rubocop:enable Style/TrivialAccessors
def percent_done
result = 100.0
if @example_count > 0
result = (((example_number).to_f / @example_count.to_f * 1000).to_i / 10.0).to_f
end
result
end
# Override this method if you wish to output extra HTML for a failed
# spec. For example, you could output links to images or other files
# produced during the specs.
def extra_failure_content(failure)
RSpec::Support.require_rspec_core "formatters/snippet_extractor"
backtrace = failure.exception.backtrace.map do |line|
RSpec.configuration.backtrace_formatter.backtrace_line(line)
end
backtrace.compact!
@snippet_extractor ||= SnippetExtractor.new
" <pre class=\"ruby\"><code>#{@snippet_extractor.snippet(backtrace)}</code></pre>"
end
end
end
end
end