Convert Bash test to spec.
This commit is contained in:
parent
46a1e2f22d
commit
f531e63949
52
Library/Homebrew/test/bash_spec.rb
Normal file
52
Library/Homebrew/test/bash_spec.rb
Normal file
@ -0,0 +1,52 @@
|
||||
require "open3"
|
||||
|
||||
RSpec::Matchers.define :have_valid_bash_syntax do
|
||||
match do |file|
|
||||
stdout, stderr, status = Open3.capture3("/bin/bash", "-n", file)
|
||||
|
||||
@actual = [file, stderr]
|
||||
|
||||
stdout.empty? && status.success?
|
||||
end
|
||||
|
||||
failure_message do |(file, stderr)|
|
||||
"expected that #{file} is a valid Bash file:\n#{stderr}"
|
||||
end
|
||||
end
|
||||
|
||||
describe "Bash" do
|
||||
context "brew" do
|
||||
subject { HOMEBREW_LIBRARY_PATH.parent.parent/"bin/brew" }
|
||||
it { is_expected.to have_valid_bash_syntax }
|
||||
end
|
||||
|
||||
context "every `.sh` file" do
|
||||
it "has valid bash syntax" do
|
||||
Pathname.glob("#{HOMEBREW_LIBRARY_PATH}/**/*.sh").each do |path|
|
||||
relative_path = path.relative_path_from(HOMEBREW_LIBRARY_PATH)
|
||||
next if relative_path.to_s.start_with?("shims/", "test/", "vendor/")
|
||||
|
||||
expect(path).to have_valid_bash_syntax
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
context "Bash completion" do
|
||||
subject { HOMEBREW_LIBRARY_PATH.parent.parent/"completions/bash/brew" }
|
||||
it { is_expected.to have_valid_bash_syntax }
|
||||
end
|
||||
|
||||
context "every shim script" do
|
||||
it "has valid bash syntax" do
|
||||
# These have no file extension, but can be identified by their shebang.
|
||||
(HOMEBREW_LIBRARY_PATH/"shims").find do |path|
|
||||
next if path.directory?
|
||||
next if path.symlink?
|
||||
next unless path.executable?
|
||||
next unless path.read(12) == "#!/bin/bash\n"
|
||||
|
||||
expect(path).to have_valid_bash_syntax
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
@ -1,35 +0,0 @@
|
||||
require "testing_env"
|
||||
|
||||
class BashTests < Homebrew::TestCase
|
||||
def assert_valid_bash_syntax(file)
|
||||
return unless file.exist?
|
||||
output = Utils.popen_read("/bin/bash -n #{file} 2>&1")
|
||||
assert $?.success?, output
|
||||
end
|
||||
|
||||
def test_bin_brew
|
||||
assert_valid_bash_syntax HOMEBREW_LIBRARY_PATH.parent.parent/"bin/brew"
|
||||
end
|
||||
|
||||
def test_bash_code
|
||||
Pathname.glob("#{HOMEBREW_LIBRARY_PATH}/**/*.sh").each do |pn|
|
||||
pn_relative = pn.relative_path_from(HOMEBREW_LIBRARY_PATH)
|
||||
next if pn_relative.to_s.start_with?("shims/", "test/", "vendor/")
|
||||
assert_valid_bash_syntax pn
|
||||
end
|
||||
end
|
||||
|
||||
def test_bash_completion
|
||||
script = HOMEBREW_LIBRARY_PATH.parent.parent/"completions/bash/brew"
|
||||
assert_valid_bash_syntax script
|
||||
end
|
||||
|
||||
def test_bash_shims
|
||||
# These have no file extension, but can be identified by their shebang.
|
||||
(HOMEBREW_LIBRARY_PATH/"shims").find do |pn|
|
||||
next if pn.directory? || pn.symlink?
|
||||
next unless pn.executable? && pn.read(12) == "#!/bin/bash\n"
|
||||
assert_valid_bash_syntax pn
|
||||
end
|
||||
end
|
||||
end
|
||||
Loading…
x
Reference in New Issue
Block a user