79 lines
1.8 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
require "rubocops/class"
describe RuboCop::Cop::FormulaAudit::Test do
subject(:cop) { described_class.new }
2021-01-12 13:33:23 +11:00
it "reports and corrects 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"
^^^^^^^^^^^^^^^^^^^^^ FormulaAudit/Test: use \#{bin} instead of /usr/local/bin in system
end
end
RUBY
2021-01-12 13:33:23 +11:00
expect_correction(<<~RUBY)
class Foo < Formula
url 'https://brew.sh/foo-1.0.tgz'
test do
2021-01-12 13:33:23 +11:00
system "\#{bin}/test"
end
end
RUBY
end
2021-01-12 13:33:23 +11:00
it "reports and corrects 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
2021-01-12 13:33:23 +11:00
shell_output("\#{bin}/test", 0)
^ FormulaAudit/Test: Passing 0 to shell_output() is redundant
end
end
RUBY
2021-01-12 13:33:23 +11:00
expect_correction(<<~RUBY)
class Foo < Formula
url 'https://brew.sh/foo-1.0.tgz'
test do
2021-01-12 13:33:23 +11:00
shell_output("\#{bin}/test")
end
end
RUBY
end
2021-01-12 13:33:23 +11:00
it "reports an offense when there is an empty test block" do
expect_offense(<<~RUBY)
2017-10-21 03:12:50 +02:00
class Foo < Formula
url 'https://brew.sh/foo-1.0.tgz'
test do
^^^^^^^ FormulaAudit/Test: `test do` should not be empty
end
end
2017-10-21 03:12:50 +02:00
RUBY
2021-01-12 13:33:23 +11:00
end
2021-01-12 13:33:23 +11:00
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
^^^^^^^ FormulaAudit/Test: `test do` should contain a real test
2021-01-12 13:33:23 +11:00
true
end
end
RUBY
end
end