lib/rubocop/cop/rspec/hooks_before_examples.rb in rubocop-rspec-1.38.1 vs lib/rubocop/cop/rspec/hooks_before_examples.rb in rubocop-rspec-1.39.0
- old
+ new
@@ -22,13 +22,10 @@
# it 'checks what foo does' do
# expect(foo).to be
# end
#
class HooksBeforeExamples < Cop
- include RangeHelp
- include RuboCop::RSpec::FinalEndLocation
-
MSG = 'Move `%<hook>s` above the examples in the group.'
def_node_matcher :example_or_group?, <<-PATTERN
{
#{(Examples::ALL + ExampleGroups::ALL).block_pattern}
@@ -43,15 +40,13 @@
end
def autocorrect(node)
lambda do |corrector|
first_example = find_first_example(node.parent)
- first_example_pos = first_example.loc.expression
- indent = "\n" + ' ' * first_example.loc.column
-
- corrector.insert_before(first_example_pos, source(node) + indent)
- corrector.remove(node_range_with_surrounding_space(node))
+ RuboCop::RSpec::Corrector::MoveNode.new(
+ node, corrector, processed_source
+ ).move_before(first_example)
end
end
private
@@ -74,22 +69,9 @@
end
end
def find_first_example(node)
node.children.find { |sibling| example_or_group?(sibling) }
- end
-
- def node_range_with_surrounding_space(node)
- range = node_range(node)
- range_by_whole_lines(range, include_final_newline: true)
- end
-
- def source(node)
- node_range(node).source
- end
-
- def node_range(node)
- node.loc.expression.with(end_pos: final_end_location(node).end_pos)
end
end
end
end
end