Class: Lucid::Formatter::Rerun
- Inherits:
-
Object
- Object
- Lucid::Formatter::Rerun
show all
- Includes:
- Io
- Defined in:
- lib/lucid/formatter/rerun.rb
Overview
The formatter used for --format rerun
This formatter keeps track of all failing features and print out their location. Example:
features/foo.feature:34 features/bar.feature:11:76:81
This formatter is used by AutoTest - it will use the output to decide what to run the next time, simply passing the output string on the command line.
Instance Method Summary
collapse
Methods included from Io
#ensure_dir, #ensure_file, #ensure_io
Constructor Details
#initialize(runtime, path_or_io, options) ⇒ Rerun
Returns a new instance of Rerun.
18
19
20
21
22
23
|
# File 'lib/lucid/formatter/rerun.rb', line 18
def initialize(runtime, path_or_io, options)
@io = ensure_io(path_or_io, "rerun")
@options = options
@file_names = []
@file_colon_lines = Hash.new{|h,k| h[k] = []}
end
|
Instance Method Details
#after_examples(*args) ⇒ Object
71
72
73
|
# File 'lib/lucid/formatter/rerun.rb', line 71
def after_examples(*args)
@in_examples = false
end
|
#after_feature ⇒ Object
30
31
32
33
34
35
36
37
38
|
# File 'lib/lucid/formatter/rerun.rb', line 30
def after_feature(*)
unless @lines.empty?
after_first_time do
@io.print ' '
end
@io.print "#{@file}:#{@lines.join(':')}"
@io.flush
end
end
|
#after_feature_element(feature_element) ⇒ Object
48
49
50
51
52
|
# File 'lib/lucid/formatter/rerun.rb', line 48
def after_feature_element(feature_element)
if (@rerun || feature_element.failed?) && !(AST::ScenarioOutline === feature_element)
@lines << feature_element.line
end
end
|
#after_features(features) ⇒ Object
40
41
42
|
# File 'lib/lucid/formatter/rerun.rb', line 40
def after_features(features)
@io.close
end
|
#after_table_row(table_row) ⇒ Object
54
55
56
57
58
59
60
61
62
63
64
|
# File 'lib/lucid/formatter/rerun.rb', line 54
def after_table_row(table_row)
return unless @in_examples and Lucid::AST::OutlineTable::ExampleRow === table_row
unless @header_row
if table_row.failed?
@rerun = true
@lines << table_row.line
end
end
@header_row = false if @header_row
end
|
#before_examples(*args) ⇒ Object
66
67
68
69
|
# File 'lib/lucid/formatter/rerun.rb', line 66
def before_examples(*args)
@header_row = true
@in_examples = true
end
|
#before_feature(feature_element) ⇒ Object
25
26
27
28
|
# File 'lib/lucid/formatter/rerun.rb', line 25
def before_feature(feature_element)
@lines = []
@file = feature_element.file
end
|
#before_feature_element(feature_element) ⇒ Object
44
45
46
|
# File 'lib/lucid/formatter/rerun.rb', line 44
def before_feature_element(feature_element)
@rerun = false
end
|
#before_table_row(table_row) ⇒ Object
75
76
77
|
# File 'lib/lucid/formatter/rerun.rb', line 75
def before_table_row(table_row)
return unless @in_examples
end
|
#step_name(keyword, step_match, status, source_indent, background, file_colon_line) ⇒ Object
79
80
81
|
# File 'lib/lucid/formatter/rerun.rb', line 79
def step_name(keyword, step_match, status, source_indent, background, file_colon_line)
@rerun = true if [:failed, :pending, :undefined].index(status)
end
|