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 |