Class: Spinach::Reporter

Inherits:
Object
  • Object
show all
Defined in:
lib/spinach/reporter.rb,
lib/spinach/reporter/stdout.rb,
lib/spinach/reporter/stdout/error_reporting.rb

Overview

Spinach reporter collects information from Runner hooks and outputs the results

Direct Known Subclasses

Stdout

Defined Under Namespace

Classes: Stdout

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(options = {}) ⇒ Reporter

Initialize a reporter with an empty error container.



10
11
12
13
14
15
16
17
18
# File 'lib/spinach/reporter.rb', line 10

def initialize(options = {})
  @errors = []
  @options = options
  @undefined_features = []
  @successful_steps = []
  @undefined_steps = []
  @failed_steps = []
  @error_steps = []
end

Instance Attribute Details

#current_featureObject (readonly)

A Hash with options for the reporter



22
23
24
# File 'lib/spinach/reporter.rb', line 22

def current_feature
  @current_feature
end

#current_scenarioObject (readonly)

A Hash with options for the reporter



22
23
24
# File 'lib/spinach/reporter.rb', line 22

def current_scenario
  @current_scenario
end

#error_stepsObject (readonly)

Returns the value of attribute error_steps.



24
25
26
# File 'lib/spinach/reporter.rb', line 24

def error_steps
  @error_steps
end

#failed_stepsObject (readonly)

Returns the value of attribute failed_steps.



24
25
26
# File 'lib/spinach/reporter.rb', line 24

def failed_steps
  @failed_steps
end

#optionsObject (readonly)

A Hash with options for the reporter



22
23
24
# File 'lib/spinach/reporter.rb', line 22

def options
  @options
end

#successful_stepsObject (readonly)

Returns the value of attribute successful_steps.



24
25
26
# File 'lib/spinach/reporter.rb', line 24

def successful_steps
  @successful_steps
end

#undefined_featuresObject (readonly)

Returns the value of attribute undefined_features.



24
25
26
# File 'lib/spinach/reporter.rb', line 24

def undefined_features
  @undefined_features
end

#undefined_stepsObject (readonly)

Returns the value of attribute undefined_steps.



24
25
26
# File 'lib/spinach/reporter.rb', line 24

def undefined_steps
  @undefined_steps
end

Instance Method Details

#after_feature_run(*args) ⇒ Object



50
# File 'lib/spinach/reporter.rb', line 50

def after_feature_run(*args); end

#after_run(*args) ⇒ Object



48
# File 'lib/spinach/reporter.rb', line 48

def after_run(*args); end

#after_scenario_run(*args) ⇒ Object



53
# File 'lib/spinach/reporter.rb', line 53

def after_scenario_run(*args); end

#before_feature_run(*args) ⇒ Object



49
# File 'lib/spinach/reporter.rb', line 49

def before_feature_run(*args); end

#before_scenario_run(*args) ⇒ Object



52
# File 'lib/spinach/reporter.rb', line 52

def before_scenario_run(*args); end

#bindObject

Hooks the reporter to the runner endpoints



27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
# File 'lib/spinach/reporter.rb', line 27

def bind
  Spinach.hooks.tap do |hooks|
    hooks.after_run { |*args| after_run(*args) }
    hooks.before_feature { |*args| before_feature_run(*args) }
    hooks.after_feature { |*args| after_feature_run(*args) }
    hooks.on_undefined_feature { |*args| on_feature_not_found(*args) }
    hooks.before_scenario { |*args| before_scenario_run(*args) }
    hooks.after_scenario { |*args| after_scenario_run(*args) }
    hooks.on_successful_step { |*args| on_successful_step(*args) }
    hooks.on_undefined_step { |*args| on_undefined_step(*args) }
    hooks.on_failed_step { |*args| on_failed_step(*args) }
    hooks.on_error_step { |*args| on_error_step(*args) }
    hooks.on_skipped_step { |*args| on_skipped_step(*args) }

    hooks.before_feature { |*args| set_current_feature(*args) }
    hooks.after_feature { |*args| clear_current_feature(*args) }
    hooks.before_scenario { |*args| set_current_scenario(*args) }
    hooks.after_scenario { |*args| clear_current_scenario(*args) }
  end
end

#clear_current_feature(*args) ⇒ Object

Clears this current feature



69
70
71
# File 'lib/spinach/reporter.rb', line 69

def clear_current_feature(*args)
  @current_feature = nil
end

#clear_current_scenario(*args) ⇒ Object

Clears this current scenario



82
83
84
# File 'lib/spinach/reporter.rb', line 82

def clear_current_scenario(*args)
  @current_scenario = nil
end

#on_error_step(*args) ⇒ Object



56
# File 'lib/spinach/reporter.rb', line 56

def on_error_step(*args); end

#on_failed_step(*args) ⇒ Object



55
# File 'lib/spinach/reporter.rb', line 55

def on_failed_step(*args); end

#on_feature_not_found(*args) ⇒ Object



51
# File 'lib/spinach/reporter.rb', line 51

def on_feature_not_found(*args); end

#on_skipped_step(*args) ⇒ Object



58
# File 'lib/spinach/reporter.rb', line 58

def on_skipped_step(*args); end

#on_successful_step(*args) ⇒ Object



54
# File 'lib/spinach/reporter.rb', line 54

def on_successful_step(*args); end

#on_undefined_step(*args) ⇒ Object



57
# File 'lib/spinach/reporter.rb', line 57

def on_undefined_step(*args); end

#set_current_feature(data) ⇒ Object

Stores the current feature

Parameters:

  • the (Hash)

    data for this feature



64
65
66
# File 'lib/spinach/reporter.rb', line 64

def set_current_feature(data)
  @current_feature = data
end

#set_current_scenario(data) ⇒ Object

Stores the current scenario

Parameters:

  • the (Hash)

    data for this scenario



77
78
79
# File 'lib/spinach/reporter.rb', line 77

def set_current_scenario(data)
  @current_scenario = data
end