Monkey patch the Spinach StdoutReporter to show scenario locations
Before: Scenario: Viewing invitation when signed out ✔ Given "John Doe" is owner of group "Owned" # features/steps/shared/group.rb:8 After: Scenario: Viewing invitation when signed out # features/invites.feature:6 ✔ Given "John Doe" is owner of group "Owned" # features/steps/shared/group.rb:8 Now if a scenario fails we can easily rerun it with a specific line number.
This commit is contained in:
parent
4cf16426da
commit
9aedf9c42c
1 changed files with 16 additions and 0 deletions
|
@ -33,3 +33,19 @@ Spinach.hooks.before_run do
|
||||||
|
|
||||||
include FactoryGirl::Syntax::Methods
|
include FactoryGirl::Syntax::Methods
|
||||||
end
|
end
|
||||||
|
|
||||||
|
module StdoutReporterWithScenarioLocation
|
||||||
|
# Override the standard reporter to show filename and line number next to each
|
||||||
|
# scenario for easy, focused re-runs
|
||||||
|
def before_scenario_run(scenario, step_definitions = nil)
|
||||||
|
@max_step_name_length = scenario.steps.map(&:name).map(&:length).max if scenario.steps.any?
|
||||||
|
name = scenario.name
|
||||||
|
|
||||||
|
# This number has no significance, it's just to line things up
|
||||||
|
max_length = @max_step_name_length + 19
|
||||||
|
out.puts "\n #{'Scenario:'.green} #{name.light_green.ljust(max_length)}" \
|
||||||
|
" # #{scenario.feature.filename}:#{scenario.line}"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
Spinach::Reporter::Stdout.prepend(StdoutReporterWithScenarioLocation)
|
||||||
|
|
Loading…
Reference in a new issue