2017-09-04 13:47:05 +05:30
|
|
|
require "rubocop"
|
|
|
|
require "rubocop/rspec/support"
|
|
|
|
require_relative "../../extend/string"
|
|
|
|
require_relative "../../rubocops/class_cop"
|
|
|
|
|
|
|
|
describe RuboCop::Cop::FormulaAudit::ClassName do
|
|
|
|
subject(:cop) { described_class.new }
|
|
|
|
|
|
|
|
context "When auditing formula" do
|
|
|
|
it "with deprecated inheritance" do
|
|
|
|
formulas = [{
|
|
|
|
"class" => "GithubGistFormula",
|
|
|
|
}, {
|
|
|
|
"class" => "ScriptFileFormula",
|
|
|
|
}, {
|
|
|
|
"class" => "AmazonWebServicesFormula",
|
|
|
|
}]
|
|
|
|
|
|
|
|
formulas.each do |formula|
|
2017-10-15 02:28:32 +02:00
|
|
|
source = <<~EOS
|
|
|
|
class Foo < #{formula["class"]}
|
|
|
|
url 'http://example.com/foo-1.0.tgz'
|
|
|
|
end
|
2017-09-04 13:47:05 +05:30
|
|
|
EOS
|
|
|
|
|
|
|
|
expected_offenses = [{ message: "#{formula["class"]} is deprecated, use Formula instead",
|
|
|
|
severity: :convention,
|
|
|
|
line: 1,
|
|
|
|
column: 12,
|
|
|
|
source: source }]
|
|
|
|
|
2017-10-07 22:31:23 +02:00
|
|
|
inspect_source(source)
|
2017-09-04 13:47:05 +05:30
|
|
|
|
|
|
|
expected_offenses.zip(cop.offenses.reverse).each do |expected, actual|
|
|
|
|
expect_offense(expected, actual)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it "with deprecated inheritance and autocorrect" do
|
2017-10-15 02:28:32 +02:00
|
|
|
source = <<~EOS
|
2017-09-04 13:47:05 +05:30
|
|
|
class Foo < AmazonWebServicesFormula
|
|
|
|
url 'http://example.com/foo-1.0.tgz'
|
|
|
|
end
|
|
|
|
EOS
|
2017-10-15 02:28:32 +02:00
|
|
|
corrected_source = <<~EOS
|
2017-09-04 13:47:05 +05:30
|
|
|
class Foo < Formula
|
|
|
|
url 'http://example.com/foo-1.0.tgz'
|
|
|
|
end
|
|
|
|
EOS
|
|
|
|
|
2017-10-07 22:31:23 +02:00
|
|
|
new_source = autocorrect_source(source)
|
2017-09-04 13:47:05 +05:30
|
|
|
expect(new_source).to eq(corrected_source)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe RuboCop::Cop::FormulaAuditStrict::Test do
|
|
|
|
subject(:cop) { described_class.new }
|
|
|
|
|
|
|
|
context "When auditing formula" do
|
|
|
|
it "without a test block" do
|
2017-10-15 02:28:32 +02:00
|
|
|
source = <<~EOS
|
2017-09-04 13:47:05 +05:30
|
|
|
class Foo < Formula
|
|
|
|
url 'http://example.com/foo-1.0.tgz'
|
|
|
|
end
|
|
|
|
EOS
|
|
|
|
expected_offenses = [{ message: described_class::MSG,
|
|
|
|
severity: :convention,
|
|
|
|
line: 1,
|
|
|
|
column: 0,
|
|
|
|
source: source }]
|
|
|
|
|
2017-10-07 22:31:23 +02:00
|
|
|
inspect_source(source)
|
2017-09-04 13:47:05 +05:30
|
|
|
|
|
|
|
expected_offenses.zip(cop.offenses).each do |expected, actual|
|
|
|
|
expect_offense(expected, actual)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|