add test for build.with? "--with-foo"
This commit is contained in:
parent
02a1406a2e
commit
5a7cbb762f
@ -303,12 +303,12 @@ module RuboCop
|
||||
problem "Don't duplicate 'without': Use `build.without? \"#{match[1]}\"` to check for \"--without-#{match[1]}\""
|
||||
end
|
||||
|
||||
# find_instance_method_call(body_node, :build, :with?) do |m|
|
||||
# arg = parameters(m).first
|
||||
# next unless match = regex_match_group(arg, %r{-?-?with-(.*)})
|
||||
# problem "Don't duplicate 'with': Use `build.with? \"#{match[1]}\"` to check for \"--with-#{match[1]}\""
|
||||
# end
|
||||
#
|
||||
find_instance_method_call(body_node, :build, :with?) do |m|
|
||||
arg = parameters(m).first
|
||||
next unless match = regex_match_group(arg, %r{-?-?with-(.*)})
|
||||
problem "Don't duplicate 'with': Use `build.with? \"#{match[1]}\"` to check for \"--with-#{match[1]}\""
|
||||
end
|
||||
|
||||
# find_instance_method_call(body_node, :build, :include?) do |m|
|
||||
# arg = parameters(m).first
|
||||
# next unless match = regex_match_group(arg, %r{with(out)?-(.*)})
|
||||
|
@ -716,7 +716,7 @@ describe RuboCop::Cop::FormulaAudit::Miscellaneous do
|
||||
end
|
||||
end
|
||||
|
||||
it "with negated build.with?" do
|
||||
it "with duplicated build.without?" do
|
||||
source = <<-EOS.undent
|
||||
class Foo < Formula
|
||||
desc "foo"
|
||||
@ -739,6 +739,30 @@ describe RuboCop::Cop::FormulaAudit::Miscellaneous do
|
||||
expect_offense(expected, actual)
|
||||
end
|
||||
end
|
||||
|
||||
it "with duplicated build.with?" do
|
||||
source = <<-EOS.undent
|
||||
class Foo < Formula
|
||||
desc "foo"
|
||||
url 'http://example.com/foo-1.0.tgz'
|
||||
def post_install
|
||||
return if build.with? "--with-bar"
|
||||
end
|
||||
end
|
||||
EOS
|
||||
|
||||
expected_offenses = [{ message: "Don't duplicate 'with': Use `build.with? \"bar\"` to check for \"--with-bar\"",
|
||||
severity: :convention,
|
||||
line: 5,
|
||||
column: 27,
|
||||
source: source }]
|
||||
|
||||
inspect_source(cop, source)
|
||||
|
||||
expected_offenses.zip(cop.offenses).each do |expected, actual|
|
||||
expect_offense(expected, actual)
|
||||
end
|
||||
end
|
||||
end
|
||||
def expect_offense(expected, actual)
|
||||
expect(actual.message).to eq(expected[:message])
|
||||
|
Loading…
x
Reference in New Issue
Block a user