Class: Micronaut::Formatters::BaseTextFormatter
Instance Attribute Summary
#behaviour, #duration, #example_count, #total_example_failed, #total_example_pending
Instance Method Summary
collapse
#add_behaviour, #color_enabled?, #configuration, #example_profiling_info, #failed_examples, #format_backtrace, #initialize, #output, #pending_examples, #profile_examples?, #start, #start_dump
Instance Method Details
103
104
105
106
107
|
# File 'lib/micronaut/formatters/base_text_formatter.rb', line 103
def close
if IO === output && output != $stdout
output.close
end
end
|
#colorise(s, failure) ⇒ Object
46
47
48
49
50
51
52
|
# File 'lib/micronaut/formatters/base_text_formatter.rb', line 46
def colorise(s, failure)
if failure.is_a?(Micronaut::Expectations::ExpectationNotMetError)
red(s)
else
magenta(s)
end
end
|
#dump_failures ⇒ Object
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
# File 'lib/micronaut/formatters/base_text_formatter.rb', line 28
def dump_failures
output.puts
failed_examples.each_with_index do |examples_with_exception, index|
example, exception = examples_with_exception.first, examples_with_exception.last
padding = ' '
output.puts "#{index.next}) #{example}"
output.puts "#{padding}Failure/Error: #{read_failed_line(exception, example).strip}"
exception.message.split("\n").each do |line|
output.puts "#{padding}#{colorise(line, exception).strip}"
end
format_backtrace(exception.backtrace, example).each do |backtrace_info|
output.puts grey("#{padding}# #{backtrace_info}")
end
output.puts
output.flush
end
end
|
#dump_pending ⇒ Object
def textmate_link_backtrace(path)
file, line = path.split(':')
"txmt://open/?url=file://#{File.expand_path(file)}&line=#{line}"
end
91
92
93
94
95
96
97
98
99
100
101
|
# File 'lib/micronaut/formatters/base_text_formatter.rb', line 91
def dump_pending
unless pending_examples.empty?
output.puts
output.puts "Pending:"
pending_examples.each do |pending_example, message|
output.puts " #{pending_example}"
output.puts grey(" # #{pending_example.metadata[:caller]}")
end
end
output.flush
end
|
#dump_summary ⇒ Object
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
|
# File 'lib/micronaut/formatters/base_text_formatter.rb', line 54
def dump_summary
failure_count = failed_examples.size
pending_count = pending_examples.size
output.puts "\nFinished in #{duration} seconds\n"
summary = "#{example_count} example#{'s' unless example_count == 1}, #{failure_count} failures"
summary << ", #{pending_count} pending" if pending_count > 0
if failure_count == 0
if pending_count > 0
output.puts yellow(summary)
else
output.puts green(summary)
end
else
output.puts red(summary)
end
if profile_examples? && failure_count == 0
sorted_examples = example_profiling_info.sort_by { |desc, time| time }.last(10)
output.puts "\nTop #{sorted_examples.size} slowest examples:\n"
sorted_examples.reverse.each do |ex, time|
output.puts " (#{sprintf("%.7f", time)} seconds) #{ex}"
output.puts grey(" # #{ex.metadata[:caller]}")
end
end
output.flush
end
|
#example_failed(example, exception) ⇒ Object
23
24
25
26
|
# File 'lib/micronaut/formatters/base_text_formatter.rb', line 23
def example_failed(example, exception)
super
failed_examples << [example, exception]
end
|
#example_passed(example) ⇒ Object
7
8
9
10
11
12
13
|
# File 'lib/micronaut/formatters/base_text_formatter.rb', line 7
def example_passed(example)
super
if profile_examples? && @start_time
example_profiling_info << [example, Time.now - @start_time]
end
end
|
#example_pending(example, message) ⇒ Object
19
20
21
|
# File 'lib/micronaut/formatters/base_text_formatter.rb', line 19
def example_pending(example, message)
pending_examples << [example, message]
end
|
#example_started(example) ⇒ Object
15
16
17
|
# File 'lib/micronaut/formatters/base_text_formatter.rb', line 15
def example_started(example)
@start_time = Time.now
end
|