brew/Library/Homebrew/test/bash_spec.rb

58 lines
1.5 KiB
Bash
Raw Normal View History

2020-10-10 14:16:11 +02:00
# typed: false
# frozen_string_literal: true
2017-02-11 16:53:11 +01:00
require "open3"
2017-05-09 23:00:51 +02:00
describe "Bash" do
matcher :have_valid_bash_syntax do
match do |file|
stdout, stderr, status = Open3.capture3("/bin/bash", "-n", file)
2017-02-11 16:53:11 +01:00
2017-05-09 23:00:51 +02:00
@actual = [file, stderr]
2017-02-11 16:53:11 +01:00
2017-05-09 23:00:51 +02:00
stdout.empty? && status.success?
end
2017-02-11 16:53:11 +01:00
2017-05-09 23:00:51 +02:00
failure_message do |(file, stderr)|
"expected that #{file} is a valid Bash file:\n#{stderr}"
end
2017-02-11 16:53:11 +01:00
end
describe "brew" do
2017-02-11 16:53:11 +01:00
subject { HOMEBREW_LIBRARY_PATH.parent.parent/"bin/brew" }
2017-02-11 16:53:11 +01:00
it { is_expected.to have_valid_bash_syntax }
end
describe "every `.sh` file" do
it "has valid Bash syntax" do
2017-02-11 16:53:11 +01:00
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
describe "Bash completion" do
2017-02-11 16:53:11 +01:00
subject { HOMEBREW_LIBRARY_PATH.parent.parent/"completions/bash/brew" }
2017-02-11 16:53:11 +01:00
it { is_expected.to have_valid_bash_syntax }
end
describe "every shim script" do
it "has valid Bash syntax" do
2017-02-11 16:53:11 +01:00
# 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