class RuboCop::Cop::RSpec::MultipleSubjects
Checks if an example group defines `subject` multiple times.
@example
# bad describe Foo do subject(:user) { User.new } subject(:post) { Post.new } end # good describe Foo do let(:user) { User.new } subject(:post) { Post.new } end
The autocorrect behavior for this cop depends on the type of duplication:
- If multiple named subjects are defined then this probably indicates that the overwritten subjects (all subjects except the last definition) are effectively being used to define helpers. In this case they are replaced with `let`. - If multiple unnamed subjects are defined though then this can *only* be dead code and we remove the overwritten subject definitions. - If subjects are defined with `subject!` then we don't autocorrect. This is enough of an edge case that people can just move this to a `before` hook on their own
Constants
- MSG
Public Instance Methods
autocorrect(node)
click to toggle source
# File lib/rubocop/cop/rspec/multiple_subjects.rb, line 52 def autocorrect(node) return unless node.method_name.equal?(:subject) # Ignore `subject!` if named_subject?(node) rename_autocorrect(node) else remove_autocorrect(node) end end
on_block(node)
click to toggle source
# File lib/rubocop/cop/rspec/multiple_subjects.rb, line 42 def on_block(node) return unless example_group?(node) subjects = RuboCop::RSpec::ExampleGroup.new(node).subjects subjects[0...-1].each do |subject| add_offense(subject, location: :expression) end end
Private Instance Methods
remove_autocorrect(node)
click to toggle source
# File lib/rubocop/cop/rspec/multiple_subjects.rb, line 71 def remove_autocorrect(node) lambda do |corrector| corrector.remove(node.loc.expression) end end
rename_autocorrect(node)
click to toggle source
# File lib/rubocop/cop/rspec/multiple_subjects.rb, line 64 def rename_autocorrect(node) lambda do |corrector| send_node, _args, _body = *node corrector.replace(send_node.loc.selector, 'let') end end