add test for build.include?

This commit is contained in:
Gautham Goli 2017-08-14 02:47:29 +05:30
parent 5a7cbb762f
commit 3ff8be1216
2 changed files with 29 additions and 5 deletions

View File

@ -309,11 +309,11 @@ module RuboCop
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)?-(.*)})
# problem "Use build.with#{match[1]}? \"#{match[2]}\" instead of build.include? 'with#{match[1]}-#{match[2]}'"
# 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)?-(.*)})
problem "Use build.with#{match[1]}? \"#{match[2]}\" instead of build.include? 'with#{match[1]}-#{match[2]}'"
end
#
# find_instance_method_call(body_node, :build, :include?) do |m|
# arg = parameters(m).first

View File

@ -763,6 +763,30 @@ describe RuboCop::Cop::FormulaAudit::Miscellaneous do
expect_offense(expected, actual)
end
end
it "with build.include?" do
source = <<-EOS.undent
class Foo < Formula
desc "foo"
url 'http://example.com/foo-1.0.tgz'
def post_install
return if build.include? "without-bar"
end
end
EOS
expected_offenses = [{ message: "Use build.without? \"bar\" instead of build.include? 'without-bar'",
severity: :convention,
line: 5,
column: 30,
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])