Add tests for MACOS version consts usage
This commit is contained in:
parent
2f94d5f499
commit
efabd4b5c2
@ -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?
|
||||||
|
|||||||
@ -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)
|
||||||
|
|||||||
@ -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])
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user