Add tests for MACOS version consts usage

This commit is contained in:
Gautham Goli 2017-08-15 00:42:56 +05:30
parent 2f94d5f499
commit efabd4b5c2
3 changed files with 34 additions and 10 deletions

View File

@ -173,8 +173,8 @@ module RuboCop
# if block given, yield matching nodes # if block given, yield matching nodes
def find_const(node, const_name) def find_const(node, const_name)
return if node.nil? return if node.nil?
node.each_child_node(:const) do |const_node| node.each_descendant(:const) do |const_node|
next if const_node.const_name != const_name next unless const_node.const_name == const_name
@offensive_node = const_node @offensive_node = const_node
@offense_source_range = const_node.source_range @offense_source_range = const_node.source_range
yield const_node if block_given? yield const_node if block_given?

View File

@ -173,14 +173,14 @@ module RuboCop
problem "Use \"if build.#{match[1].downcase}?\" instead" problem "Use \"if build.#{match[1].downcase}?\" instead"
end end
# find_const(body_node, :MACOS_VERSION) do find_const(body_node, "MACOS_VERSION") do
# problem "Use MacOS.version instead of MACOS_VERSION" problem "Use MacOS.version instead of MACOS_VERSION"
# end end
#
# find_const(body_node, :MACOS_FULL_VERSION) do find_const(body_node, "MACOS_FULL_VERSION") do
# problem "Use MacOS.full_version instead of MACOS_FULL_VERSION" problem "Use MacOS.full_version instead of MACOS_FULL_VERSION"
# end end
#
# dependency(body_node) do |m| # dependency(body_node) do |m|
# # handle symbols and shit: WIP # # handle symbols and shit: WIP
# next unless modifier?(m.parent) # next unless modifier?(m.parent)

View File

@ -1189,6 +1189,30 @@ describe RuboCop::Cop::FormulaAudit::Miscellaneous do
end end
end end
it "with MACOS_VERSION const" do
source = <<-EOS.undent
class Foo < Formula
desc "foo"
url 'http://example.com/foo-1.0.tgz'
test do
version = MACOS_VERSION
end
end
EOS
expected_offenses = [{ message: "Use MacOS.version instead of MACOS_VERSION",
severity: :convention,
line: 5,
column: 14,
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])