mirror of
https://github.com/Homebrew/brew.git
synced 2025-07-14 16:09:03 +08:00
146 lines
3.5 KiB
Ruby
146 lines
3.5 KiB
Ruby
# typed: false
|
|
# frozen_string_literal: true
|
|
|
|
require "rubocops/class"
|
|
|
|
describe RuboCop::Cop::FormulaAudit::ClassName do
|
|
subject(:cop) { described_class.new }
|
|
|
|
it "reports an offense when using ScriptFileFormula" do
|
|
expect_offense(<<~RUBY)
|
|
class Foo < ScriptFileFormula
|
|
^^^^^^^^^^^^^^^^^ ScriptFileFormula is deprecated, use Formula instead
|
|
url 'https://brew.sh/foo-1.0.tgz'
|
|
end
|
|
RUBY
|
|
end
|
|
|
|
it "reports an offense when using GithubGistFormula" do
|
|
expect_offense(<<~RUBY)
|
|
class Foo < GithubGistFormula
|
|
^^^^^^^^^^^^^^^^^ GithubGistFormula is deprecated, use Formula instead
|
|
url 'https://brew.sh/foo-1.0.tgz'
|
|
end
|
|
RUBY
|
|
end
|
|
|
|
it "reports an offense when using AmazonWebServicesFormula" do
|
|
expect_offense(<<~RUBY)
|
|
class Foo < AmazonWebServicesFormula
|
|
^^^^^^^^^^^^^^^^^^^^^^^^ AmazonWebServicesFormula is deprecated, use Formula instead
|
|
url 'https://brew.sh/foo-1.0.tgz'
|
|
end
|
|
RUBY
|
|
end
|
|
|
|
it "supports auto-correcting deprecated parent classes" do
|
|
source = <<~RUBY
|
|
class Foo < AmazonWebServicesFormula
|
|
url 'https://brew.sh/foo-1.0.tgz'
|
|
end
|
|
RUBY
|
|
|
|
corrected_source = <<~RUBY
|
|
class Foo < Formula
|
|
url 'https://brew.sh/foo-1.0.tgz'
|
|
end
|
|
RUBY
|
|
|
|
new_source = autocorrect_source(source)
|
|
expect(new_source).to eq(corrected_source)
|
|
end
|
|
end
|
|
|
|
describe RuboCop::Cop::FormulaAudit::Test do
|
|
subject(:cop) { described_class.new }
|
|
|
|
it "reports an offense when /usr/local/bin is found in test calls" do
|
|
expect_offense(<<~RUBY)
|
|
class Foo < Formula
|
|
url 'https://brew.sh/foo-1.0.tgz'
|
|
|
|
test do
|
|
system "/usr/local/bin/test"
|
|
^^^^^^^^^^^^^^^^^^^^^ use \#{bin} instead of /usr/local/bin in system
|
|
end
|
|
end
|
|
RUBY
|
|
end
|
|
|
|
it "reports an offense when passing 0 as the second parameter to shell_output" do
|
|
expect_offense(<<~RUBY)
|
|
class Foo < Formula
|
|
url 'https://brew.sh/foo-1.0.tgz'
|
|
|
|
test do
|
|
shell_output("\#{bin}/test", 0)
|
|
^ Passing 0 to shell_output() is redundant
|
|
end
|
|
end
|
|
RUBY
|
|
end
|
|
|
|
it "reports an offense when there is an empty test block" do
|
|
expect_offense(<<~RUBY)
|
|
class Foo < Formula
|
|
url 'https://brew.sh/foo-1.0.tgz'
|
|
|
|
test do
|
|
^^^^^^^ `test do` should not be empty
|
|
end
|
|
end
|
|
RUBY
|
|
end
|
|
|
|
it "reports an offense when test is falsely true" do
|
|
expect_offense(<<~RUBY)
|
|
class Foo < Formula
|
|
url 'https://brew.sh/foo-1.0.tgz'
|
|
|
|
test do
|
|
^^^^^^^ `test do` should contain a real test
|
|
true
|
|
end
|
|
end
|
|
RUBY
|
|
end
|
|
|
|
it "supports auto-correcting test calls" do
|
|
source = <<~RUBY
|
|
class Foo < Formula
|
|
url 'https://brew.sh/foo-1.0.tgz'
|
|
|
|
test do
|
|
shell_output("/usr/local/sbin/test", 0)
|
|
end
|
|
end
|
|
RUBY
|
|
|
|
corrected_source = <<~RUBY
|
|
class Foo < Formula
|
|
url 'https://brew.sh/foo-1.0.tgz'
|
|
|
|
test do
|
|
shell_output("\#{sbin}/test")
|
|
end
|
|
end
|
|
RUBY
|
|
|
|
new_source = autocorrect_source(source)
|
|
expect(new_source).to eq(corrected_source)
|
|
end
|
|
end
|
|
|
|
describe RuboCop::Cop::FormulaAuditStrict::TestPresent do
|
|
subject(:cop) { described_class.new }
|
|
|
|
it "reports an offense when there is no test block" do
|
|
expect_offense(<<~RUBY)
|
|
class Foo < Formula
|
|
^^^^^^^^^^^^^^^^^^^ A `test do` test block should be added
|
|
url 'https://brew.sh/foo-1.0.tgz'
|
|
end
|
|
RUBY
|
|
end
|
|
end
|