add test for build.with? "--with-foo"

This commit is contained in:
Gautham Goli 2017-08-14 02:43:54 +05:30
parent 02a1406a2e
commit 5a7cbb762f
2 changed files with 31 additions and 7 deletions

View File

@ -303,12 +303,12 @@ module RuboCop
problem "Don't duplicate 'without': Use `build.without? \"#{match[1]}\"` to check for \"--without-#{match[1]}\"" problem "Don't duplicate 'without': Use `build.without? \"#{match[1]}\"` to check for \"--without-#{match[1]}\""
end end
# find_instance_method_call(body_node, :build, :with?) do |m| find_instance_method_call(body_node, :build, :with?) do |m|
# arg = parameters(m).first arg = parameters(m).first
# next unless match = regex_match_group(arg, %r{-?-?with-(.*)}) 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]}\"" problem "Don't duplicate 'with': Use `build.with? \"#{match[1]}\"` to check for \"--with-#{match[1]}\""
# end end
#
# find_instance_method_call(body_node, :build, :include?) do |m| # find_instance_method_call(body_node, :build, :include?) do |m|
# arg = parameters(m).first # arg = parameters(m).first
# next unless match = regex_match_group(arg, %r{with(out)?-(.*)}) # next unless match = regex_match_group(arg, %r{with(out)?-(.*)})

View File

@ -716,7 +716,7 @@ describe RuboCop::Cop::FormulaAudit::Miscellaneous do
end end
end end
it "with negated build.with?" do it "with duplicated build.without?" do
source = <<-EOS.undent source = <<-EOS.undent
class Foo < Formula class Foo < Formula
desc "foo" desc "foo"
@ -739,6 +739,30 @@ describe RuboCop::Cop::FormulaAudit::Miscellaneous do
expect_offense(expected, actual) expect_offense(expected, actual)
end end
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 end
def expect_offense(expected, actual) def expect_offense(expected, actual)
expect(actual.message).to eq(expected[:message]) expect(actual.message).to eq(expected[:message])