add test for inspecting version

This commit is contained in:
Gautham Goli 2017-08-15 00:29:58 +05:30
parent cfc423e183
commit 5744cd9066
2 changed files with 29 additions and 5 deletions

View File

@ -157,11 +157,11 @@ module RuboCop
problem "Dependency #{string_content(dep)} should not use option #{string_content(option)}" problem "Dependency #{string_content(dep)} should not use option #{string_content(option)}"
end end
# find_instance_method_call(body_node, :version, :==) do |m| find_instance_method_call(body_node, :version, :==) do |m|
# next unless parameters_passed?(m, "HEAD") next unless parameters_passed?(m, "HEAD")
# problem "Use 'build.head?' instead of inspecting 'version'" problem "Use 'build.head?' instead of inspecting 'version'"
# end end
#
# find_instance_method_call(body_node, :ENV, :fortran) do # find_instance_method_call(body_node, :ENV, :fortran) do
# next if depends_on?(:fortran) # next if depends_on?(:fortran)
# problem "Use `depends_on :fortran` instead of `ENV.fortran`" # problem "Use `depends_on :fortran` instead of `ENV.fortran`"

View File

@ -1117,6 +1117,30 @@ describe RuboCop::Cop::FormulaAudit::Miscellaneous do
end end
end end
it "with inspecting version" do
source = <<-EOS.undent
class Foo < Formula
desc "foo"
url 'http://example.com/foo-1.0.tgz'
if version == "HEAD"
foo()
end
end
EOS
expected_offenses = [{ message: "Use 'build.head?' instead of inspecting 'version'",
severity: :convention,
line: 4,
column: 5,
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])