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, #trace, #trace_override_flag
Instance Method Details
108
109
110
111
112
|
# File 'lib/micronaut/formatters/base_text_formatter.rb', line 108
def close
if IO === output && output != $stdout
output.close
end
end
|
#colorise(s, failure) ⇒ Object
#dump_failures ⇒ Object
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
# File 'lib/micronaut/formatters/base_text_formatter.rb', line 29
def dump_failures
output.puts
failed_examples.each_with_index do |examples_with_exception, index|
failed_example, exception = examples_with_exception.first, examples_with_exception.last
padding = ' '
output.puts "#{index.next}) #{failed_example}"
output.puts "#{padding}Failure/Error: #{read_failed_line(exception, failed_example).strip}"
exception.message.split("\n").each do |line|
output.puts "#{padding}#{colorise(line, exception).strip}"
end
format_backtrace(exception.backtrace, failed_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
96
97
98
99
100
101
102
103
104
105
106
|
# File 'lib/micronaut/formatters/base_text_formatter.rb', line 96
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
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
|
# File 'lib/micronaut/formatters/base_text_formatter.rb', line 59
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
24
25
26
27
|
# File 'lib/micronaut/formatters/base_text_formatter.rb', line 24
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
20
21
22
|
# File 'lib/micronaut/formatters/base_text_formatter.rb', line 20
def example_pending(example, message)
pending_examples << [example, message]
end
|
#example_started(example) ⇒ Object
15
16
17
18
|
# File 'lib/micronaut/formatters/base_text_formatter.rb', line 15
def example_started(example)
super
@start_time = Time.now
end
|