lib/knapsack_pro/adapters/cucumber_adapter.rb
# frozen_string_literal: true
module KnapsackPro
module Adapters
class CucumberAdapter < BaseAdapter
TEST_DIR_PATTERN = 'features/**{,/*/**}/*.feature'
def self.test_path(object)
if ::Cucumber::VERSION.to_i >= 2
test_case = object
test_case.location.file
else
if object.respond_to?(:scenario_outline)
if object.scenario_outline.respond_to?(:feature)
# Cucumber < 1.3
object.scenario_outline.feature.file
else
# Cucumber >= 1.3
object.scenario_outline.file
end
else
if object.respond_to?(:feature)
# Cucumber < 1.3
object.feature.file
else
# Cucumber >= 1.3
object.file
end
end
end
end
def bind_time_tracker
Around do |object, block|
KnapsackPro.tracker.current_test_path = KnapsackPro::Adapters::CucumberAdapter.test_path(object)
KnapsackPro.tracker.start_timer
block.call
KnapsackPro.tracker.stop_timer
end
::Kernel.at_exit do
KnapsackPro.logger.debug(KnapsackPro::Presenter.global_time)
end
end
def bind_save_report(latest_error = nil)
::Kernel.at_exit do
# $! is latest error message
latest_error = (latest_error || $!)
exit_status = latest_error.status if latest_error.is_a?(SystemExit)
# saving report makes API call which changes exit status
# from cucumber so we need to preserve cucumber exit status
KnapsackPro::Report.save
::Kernel.exit exit_status if exit_status
end
end
def bind_before_queue_hook
Around do |object, block|
unless ENV['KNAPSACK_PRO_BEFORE_QUEUE_HOOK_CALLED']
KnapsackPro::Hooks::Queue.call_before_queue
ENV['KNAPSACK_PRO_BEFORE_QUEUE_HOOK_CALLED'] = 'true'
end
block.call
end
end
def bind_after_queue_hook
::Kernel.at_exit do
KnapsackPro::Hooks::Queue.call_after_subset_queue
KnapsackPro::Report.save_subset_queue_to_file
end
end
private
def Around(*tag_expressions, &proc)
if ::Cucumber::VERSION.to_i >= 3
::Cucumber::Glue::Dsl.register_rb_hook('around', tag_expressions, proc)
else
::Cucumber::RbSupport::RbDsl.register_rb_hook('around', tag_expressions, proc)
end
end
end
end
end