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
|
|
|
|
|
|
|
|
context "brew" do
|
|
|
|
subject { HOMEBREW_LIBRARY_PATH.parent.parent/"bin/brew" }
|
2018-03-25 13:30:37 +01:00
|
|
|
|
2017-02-11 16:53:11 +01:00
|
|
|
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" }
|
2018-03-25 13:30:37 +01:00
|
|
|
|
2017-02-11 16:53:11 +01:00
|
|
|
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
|