mirror of
https://github.com/Homebrew/brew.git
synced 2025-07-14 16:09:03 +08:00
213 lines
5.7 KiB
Ruby
213 lines
5.7 KiB
Ruby
![]() |
# typed: false
|
||
|
# frozen_string_literal: true
|
||
|
|
||
|
require "rubocops/lines"
|
||
|
|
||
|
describe RuboCop::Cop::FormulaAuditStrict::ShellCommands do
|
||
|
subject(:cop) { described_class.new }
|
||
|
|
||
|
context "when auditing shell commands" do
|
||
|
it "reports and corrects an offense when `system` arguments should be separated" do
|
||
|
expect_offense(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
system "foo bar"
|
||
|
^^^^^^^^^ Separate `system` commands into `\"foo\", \"bar\"`
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
|
||
|
expect_correction(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
system "foo", "bar"
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
end
|
||
|
|
||
|
it "reports and corrects an offense when `system` arguments with string interpolation should be separated" do
|
||
|
expect_offense(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
system "\#{bin}/foo bar"
|
||
|
^^^^^^^^^^^^^^^^ Separate `system` commands into `\"\#{bin}/foo\", \"bar\"`
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
|
||
|
expect_correction(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
system "\#{bin}/foo", "bar"
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
end
|
||
|
|
||
|
it "reports no offenses when `system` with metacharacter arguments are called" do
|
||
|
expect_no_offenses(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
system "foo bar > baz"
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
end
|
||
|
|
||
|
it "reports no offenses when trailing arguments to `system` are unseparated" do
|
||
|
expect_no_offenses(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
system "foo", "bar baz"
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
end
|
||
|
|
||
|
it "reports no offenses when `Utils.popen` arguments are unseparated" do
|
||
|
expect_no_offenses(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
Utils.popen("foo bar")
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
end
|
||
|
|
||
|
it "reports and corrects an offense when `Utils.popen_read` arguments are unseparated" do
|
||
|
expect_offense(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
Utils.popen_read("foo bar")
|
||
|
^^^^^^^^^ Separate `Utils.popen_read` commands into `\"foo\", \"bar\"`
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
|
||
|
expect_correction(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
Utils.popen_read("foo", "bar")
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
end
|
||
|
|
||
|
it "reports and corrects an offense when `Utils.safe_popen_read` arguments are unseparated" do
|
||
|
expect_offense(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
Utils.safe_popen_read("foo bar")
|
||
|
^^^^^^^^^ Separate `Utils.safe_popen_read` commands into `\"foo\", \"bar\"`
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
|
||
|
expect_correction(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
Utils.safe_popen_read("foo", "bar")
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
end
|
||
|
|
||
|
it "reports and corrects an offense when `Utils.popen_write` arguments are unseparated" do
|
||
|
expect_offense(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
Utils.popen_write("foo bar")
|
||
|
^^^^^^^^^ Separate `Utils.popen_write` commands into `\"foo\", \"bar\"`
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
|
||
|
expect_correction(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
Utils.popen_write("foo", "bar")
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
end
|
||
|
|
||
|
it "reports and corrects an offense when `Utils.safe_popen_write` arguments are unseparated" do
|
||
|
expect_offense(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
Utils.safe_popen_write("foo bar")
|
||
|
^^^^^^^^^ Separate `Utils.safe_popen_write` commands into `\"foo\", \"bar\"`
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
|
||
|
expect_correction(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
Utils.safe_popen_write("foo", "bar")
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
end
|
||
|
|
||
|
it "reports and corrects an offense when `Utils.popen_read` arguments with interpolation are unseparated" do
|
||
|
expect_offense(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
Utils.popen_read("\#{bin}/foo bar")
|
||
|
^^^^^^^^^^^^^^^^ Separate `Utils.popen_read` commands into `\"\#{bin}/foo\", \"bar\"`
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
|
||
|
expect_correction(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
Utils.popen_read("\#{bin}/foo", "bar")
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
end
|
||
|
|
||
|
it "reports no offenses when `Utils.popen_read` arguments with metacharacters are unseparated" do
|
||
|
expect_no_offenses(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
Utils.popen_read("foo bar > baz")
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
end
|
||
|
|
||
|
it "reports no offenses when trailing arguments to `Utils.popen_read` are unseparated" do
|
||
|
expect_no_offenses(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
Utils.popen_read("foo", "bar baz")
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
end
|
||
|
|
||
|
it "reports and corrects an offense when `Utils.popen_read` arguments are unseparated after a shell variable" do
|
||
|
expect_offense(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
Utils.popen_read({ "SHELL" => "bash"}, "foo bar")
|
||
|
^^^^^^^^^ Separate `Utils.popen_read` commands into `\"foo\", \"bar\"`
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
|
||
|
expect_correction(<<~RUBY)
|
||
|
class Foo < Formula
|
||
|
def install
|
||
|
Utils.popen_read({ "SHELL" => "bash"}, "foo", "bar")
|
||
|
end
|
||
|
end
|
||
|
RUBY
|
||
|
end
|
||
|
end
|
||
|
end
|